diff --git a/gulpfile.js b/gulpfile.js
new file mode 100644
index 000000000..18d6dbe86
--- /dev/null
+++ b/gulpfile.js
@@ -0,0 +1,136 @@
+//var gulp = require('gulp');
+//var browserify = require('browserify');
+//var source = require('vinyl-source-stream');
+//
+
+
+//var gulp = require('gulp');
+//var glob = require('glob');
+//var browserify = require('browserify');
+//var source = require('vinyl-source-stream');
+//
+//gulp.task('browserify', function(){
+// var testFiles = glob.sync('./build/away/**/*.js');
+// return browserify({
+// debug: true,
+// entries: testFiles,
+// paths: ['./build/away']
+// })
+// .bundle()
+// .pipe(source('away.js'))
+// .pipe(gulp.dest('./build'));
+//});
+//
+//gulp.task('default', ['browserify']);
+
+var concat = require('gulp-concat');
+var gulp = require('gulp');
+var changed = require('gulp-changed');
+var glob = require('glob');
+var path = require('path');
+var browserify = require('browserify');
+var source = require('vinyl-source-stream');
+var map = require('vinyl-map');
+var exorcist = require('exorcist');
+var sourcemaps = require('gulp-sourcemaps');
+
+var typescript = require('gulp-typescript');
+
+//var project = {
+// declaration: true,
+// sourcemap: true,
+// noResolve: false,
+// target: 'ES5',
+// module: 'commonjs'
+//};
+//
+//gulp.task('compile', function() {
+// return gulp.src(['./lib/**/*.ts'])
+// //.pipe(changed('./out/', {extension:'.js', hasChanged: changed.compareLastModifiedTime}))
+// .pipe(tsc(project))
+// .pipe(gulp.dest('out/'));
+//});
+//
+//gulp.task('watch', ['scripts'], function() {
+// gulp.watch('lib/**/*.ts', ['scripts']);
+//});
+
+gulp.task('compile', function() {
+ var tsProject = typescript.createProject({
+ declarationFiles: true,
+ noExternalResolve: true,
+ target: 'ES5',
+ module: 'commonjs'
+ });
+
+ var ambientWrap = map(function(code, filename) {
+ code = code.toString();
+ code = 'declare module "' + path.relative('../', filename.slice(0,-5)) + '" {\n\t'
+ + code.split('declare ').join('').split('\n').join('\n\t') + "\n"
+ + '}';
+ return code;
+ });
+
+ var tsResult = gulp.src(['./lib/**/*.ts', './node_modules/awayjs-**/build/*.d.ts'])
+ .pipe(sourcemaps.init())
+ .pipe(typescript(tsProject));
+
+ tsResult.dts
+ .pipe(ambientWrap)
+ .pipe(concat('awayjs-renderergl.d.ts'))
+ .pipe(gulp.dest('./build'));
+
+ return tsResult.js
+ .pipe(sourcemaps.write())
+ .pipe(gulp.dest('./lib'));
+});
+
+gulp.task('watch', ['package'], function() {
+ gulp.watch('./lib/**/*.ts', ['package']);
+});
+
+gulp.task('package', ['compile'], function(callback){
+ var b = browserify({
+ debug: true,
+ paths: ['../']
+ });
+
+ glob('./node_modules/awayjs-**/lib/**/*.js', {}, function (error, files) {
+ files.forEach(function (file) {
+ b.external(file);
+ });
+ });
+
+ glob('./lib/**/*.js', {}, function (error, files) {
+
+ files.forEach(function (file) {
+ b.require(file, {expose:path.relative('../', file.slice(0,-3))});
+ });
+
+ b.bundle()
+ .pipe(exorcist('./build/awayjs-renderergl.js.map'))
+ .pipe(source('awayjs-renderergl.js'))
+ .pipe(gulp.dest('./build'))
+ .on('end', callback);
+ });
+});
+
+
+gulp.task('tests', function () {
+
+ var tsProject = typescript.createProject({
+ declarationFiles: true,
+ noExternalResolve: true,
+ target: 'ES5',
+ module: 'commonjs'
+ });
+
+ var tsResult = gulp.src(['./tests/**/*.ts', './node_modules/awayjs-**/build/*.d.ts', './build/awayjs-renderergl.d.ts'])
+ //.pipe(changed('./tests', {extension:'.js', hasChanged: changed.compareLastModifiedTime}))
+ .pipe(sourcemaps.init())
+ .pipe(typescript(tsProject));
+
+ return tsResult.js
+ .pipe(sourcemaps.write())
+ .pipe(gulp.dest('./tests'));
+});
\ No newline at end of file
diff --git a/lib/animators/ParticleAnimationSet.js b/lib/animators/ParticleAnimationSet.js
new file mode 100755
index 000000000..1a9d0484f
--- /dev/null
+++ b/lib/animators/ParticleAnimationSet.js
@@ -0,0 +1,301 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var AnimationSetBase = require("awayjs-stagegl/lib/animators/AnimationSetBase");
+var AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+var AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+var ParticleAnimationData = require("awayjs-renderergl/lib/animators/data/ParticleAnimationData");
+var ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleTimeNode = require("awayjs-renderergl/lib/animators/nodes/ParticleTimeNode");
+/**
+ * The animation data set used by particle-based animators, containing particle animation data.
+ *
+ * @see away.animators.ParticleAnimator
+ */
+var ParticleAnimationSet = (function (_super) {
+ __extends(ParticleAnimationSet, _super);
+ /**
+ * Creates a new ParticleAnimationSet
+ *
+ * @param [optional] usesDuration Defines whether the animation set uses the duration
data in its static properties to determine how long a particle is visible for. Defaults to false.
+ * @param [optional] usesLooping Defines whether the animation set uses a looping timeframe for each particle determined by the startTime
, duration
and delay
data in its static properties function. Defaults to false. Requires usesDuration
to be true.
+ * @param [optional] usesDelay Defines whether the animation set uses the delay
data in its static properties to determine how long a particle is hidden for. Defaults to false. Requires usesLooping
to be true.
+ */
+ function ParticleAnimationSet(usesDuration, usesLooping, usesDelay) {
+ if (usesDuration === void 0) { usesDuration = false; }
+ if (usesLooping === void 0) { usesLooping = false; }
+ if (usesDelay === void 0) { usesDelay = false; }
+ _super.call(this);
+ this._animationSubGeometries = new Object();
+ this._particleNodes = new Array();
+ this._localDynamicNodes = new Array();
+ this._localStaticNodes = new Array();
+ this._totalLenOfOneVertex = 0;
+ //automatically add a particle time node to the set
+ this.addAnimation(this._timeNode = new ParticleTimeNode(usesDuration, usesLooping, usesDelay));
+ }
+ Object.defineProperty(ParticleAnimationSet.prototype, "particleNodes", {
+ /**
+ * Returns a vector of the particle animation nodes contained within the set.
+ */
+ get: function () {
+ return this._particleNodes;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ ParticleAnimationSet.prototype.addAnimation = function (node) {
+ var i /*int*/;
+ var n = node;
+ n._iProcessAnimationSetting(this);
+ if (n.mode == ParticlePropertiesMode.LOCAL_STATIC) {
+ n._iDataOffset = this._totalLenOfOneVertex;
+ this._totalLenOfOneVertex += n.dataLength;
+ this._localStaticNodes.push(n);
+ }
+ else if (n.mode == ParticlePropertiesMode.LOCAL_DYNAMIC)
+ this._localDynamicNodes.push(n);
+ for (i = this._particleNodes.length - 1; i >= 0; i--) {
+ if (this._particleNodes[i].priority <= n.priority)
+ break;
+ }
+ this._particleNodes.splice(i + 1, 0, n);
+ _super.prototype.addAnimation.call(this, node);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleAnimationSet.prototype.activate = function (shaderObject, stage) {
+ // this._iAnimationRegisterCache = pass.animationRegisterCache;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleAnimationSet.prototype.deactivate = function (shaderObject, stage) {
+ // var context:IContextStageGL = stage.context;
+ // var offset:number /*int*/ = this._iAnimationRegisterCache.vertexAttributesOffset;
+ // var used:number /*int*/ = this._iAnimationRegisterCache.numUsedStreams;
+ // for (var i:number /*int*/ = offset; i < used; i++)
+ // context.setVertexBufferAt(i, null);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleAnimationSet.prototype.getAGALVertexCode = function (shaderObject) {
+ //grab animationRegisterCache from the materialpassbase or create a new one if the first time
+ this._iAnimationRegisterCache = shaderObject.animationRegisterCache;
+ if (this._iAnimationRegisterCache == null)
+ this._iAnimationRegisterCache = shaderObject.animationRegisterCache = new AnimationRegisterCache(shaderObject.profile);
+ //reset animationRegisterCache
+ this._iAnimationRegisterCache.vertexConstantOffset = shaderObject.numUsedVertexConstants;
+ this._iAnimationRegisterCache.vertexAttributesOffset = shaderObject.numUsedStreams;
+ this._iAnimationRegisterCache.varyingsOffset = shaderObject.numUsedVaryings;
+ this._iAnimationRegisterCache.fragmentConstantOffset = shaderObject.numUsedFragmentConstants;
+ this._iAnimationRegisterCache.hasUVNode = this.hasUVNode;
+ this._iAnimationRegisterCache.needVelocity = this.needVelocity;
+ this._iAnimationRegisterCache.hasBillboard = this.hasBillboard;
+ this._iAnimationRegisterCache.sourceRegisters = shaderObject.animatableAttributes;
+ this._iAnimationRegisterCache.targetRegisters = shaderObject.animationTargetRegisters;
+ this._iAnimationRegisterCache.needFragmentAnimation = shaderObject.usesFragmentAnimation;
+ this._iAnimationRegisterCache.needUVAnimation = !shaderObject.usesUVTransform;
+ this._iAnimationRegisterCache.hasColorAddNode = this.hasColorAddNode;
+ this._iAnimationRegisterCache.hasColorMulNode = this.hasColorMulNode;
+ this._iAnimationRegisterCache.reset();
+ var code = "";
+ code += this._iAnimationRegisterCache.getInitCode();
+ var node;
+ var i /*int*/;
+ for (i = 0; i < this._particleNodes.length; i++) {
+ node = this._particleNodes[i];
+ if (node.priority < ParticleAnimationSet.POST_PRIORITY)
+ code += node.getAGALVertexCode(shaderObject, this._iAnimationRegisterCache);
+ }
+ code += this._iAnimationRegisterCache.getCombinationCode();
+ for (i = 0; i < this._particleNodes.length; i++) {
+ node = this._particleNodes[i];
+ if (node.priority >= ParticleAnimationSet.POST_PRIORITY && node.priority < ParticleAnimationSet.COLOR_PRIORITY)
+ code += node.getAGALVertexCode(shaderObject, this._iAnimationRegisterCache);
+ }
+ code += this._iAnimationRegisterCache.initColorRegisters();
+ for (i = 0; i < this._particleNodes.length; i++) {
+ node = this._particleNodes[i];
+ if (node.priority >= ParticleAnimationSet.COLOR_PRIORITY)
+ code += node.getAGALVertexCode(shaderObject, this._iAnimationRegisterCache);
+ }
+ code += this._iAnimationRegisterCache.getColorPassCode();
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleAnimationSet.prototype.getAGALUVCode = function (shaderObject) {
+ var code = "";
+ if (this.hasUVNode) {
+ this._iAnimationRegisterCache.setUVSourceAndTarget(shaderObject.uvSource, shaderObject.uvTarget);
+ code += "mov " + this._iAnimationRegisterCache.uvTarget + ".xy," + this._iAnimationRegisterCache.uvAttribute.toString() + "\n";
+ var node;
+ for (var i = 0; i < this._particleNodes.length; i++)
+ node = this._particleNodes[i];
+ code += node.getAGALUVCode(shaderObject, this._iAnimationRegisterCache);
+ code += "mov " + this._iAnimationRegisterCache.uvVar.toString() + "," + this._iAnimationRegisterCache.uvTarget + ".xy\n";
+ }
+ else
+ code += "mov " + shaderObject.uvTarget + "," + shaderObject.uvSource + "\n";
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleAnimationSet.prototype.getAGALFragmentCode = function (shaderObject, shadedTarget) {
+ return this._iAnimationRegisterCache.getColorCombinationCode(shadedTarget);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleAnimationSet.prototype.doneAGALCode = function (shaderObject) {
+ this._iAnimationRegisterCache.setDataLength();
+ //set vertexZeroConst,vertexOneConst,vertexTwoConst
+ this._iAnimationRegisterCache.setVertexConst(this._iAnimationRegisterCache.vertexZeroConst.index, 0, 1, 2, 0);
+ };
+ Object.defineProperty(ParticleAnimationSet.prototype, "usesCPU", {
+ /**
+ * @inheritDoc
+ */
+ get: function () {
+ return false;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ ParticleAnimationSet.prototype.cancelGPUCompatibility = function () {
+ };
+ ParticleAnimationSet.prototype.dispose = function () {
+ for (var key in this._animationSubGeometries)
+ this._animationSubGeometries[key].dispose();
+ _super.prototype.dispose.call(this);
+ };
+ ParticleAnimationSet.prototype.getAnimationSubGeometry = function (subMesh) {
+ var mesh = subMesh.parentMesh;
+ var animationSubGeometry = (mesh.shareAnimationGeometry) ? this._animationSubGeometries[subMesh.subGeometry.id] : this._animationSubGeometries[subMesh.id];
+ if (animationSubGeometry)
+ return animationSubGeometry;
+ this._iGenerateAnimationSubGeometries(mesh);
+ return (mesh.shareAnimationGeometry) ? this._animationSubGeometries[subMesh.subGeometry.id] : this._animationSubGeometries[subMesh.id];
+ };
+ /** @private */
+ ParticleAnimationSet.prototype._iGenerateAnimationSubGeometries = function (mesh) {
+ if (this.initParticleFunc == null)
+ throw (new Error("no initParticleFunc set"));
+ var geometry = mesh.geometry;
+ if (!geometry)
+ throw (new Error("Particle animation can only be performed on a ParticleGeometry object"));
+ var i /*int*/, j /*int*/, k /*int*/;
+ var animationSubGeometry;
+ var newAnimationSubGeometry = false;
+ var subGeometry;
+ var subMesh;
+ var localNode;
+ for (i = 0; i < mesh.subMeshes.length; i++) {
+ subMesh = mesh.subMeshes[i];
+ subGeometry = subMesh.subGeometry;
+ if (mesh.shareAnimationGeometry) {
+ animationSubGeometry = this._animationSubGeometries[subGeometry.id];
+ if (animationSubGeometry)
+ continue;
+ }
+ animationSubGeometry = new AnimationSubGeometry();
+ if (mesh.shareAnimationGeometry)
+ this._animationSubGeometries[subGeometry.id] = animationSubGeometry;
+ else
+ this._animationSubGeometries[subMesh.id] = animationSubGeometry;
+ newAnimationSubGeometry = true;
+ //create the vertexData vector that will be used for local node data
+ animationSubGeometry.createVertexData(subGeometry.numVertices, this._totalLenOfOneVertex);
+ }
+ if (!newAnimationSubGeometry)
+ return;
+ var particles = geometry.particles;
+ var particlesLength = particles.length;
+ var numParticles = geometry.numParticles;
+ var particleProperties = new ParticleProperties();
+ var particle;
+ var oneDataLen /*int*/;
+ var oneDataOffset /*int*/;
+ var counterForVertex /*int*/;
+ var counterForOneData /*int*/;
+ var oneData;
+ var numVertices /*uint*/;
+ var vertexData;
+ var vertexLength /*uint*/;
+ var startingOffset /*uint*/;
+ var vertexOffset /*uint*/;
+ //default values for particle param
+ particleProperties.total = numParticles;
+ particleProperties.startTime = 0;
+ particleProperties.duration = 1000;
+ particleProperties.delay = 0.1;
+ i = 0;
+ j = 0;
+ while (i < numParticles) {
+ particleProperties.index = i;
+ //call the init on the particle parameters
+ this.initParticleFunc.call(this.initParticleScope, particleProperties);
+ for (k = 0; k < this._localStaticNodes.length; k++)
+ this._localStaticNodes[k]._iGeneratePropertyOfOneParticle(particleProperties);
+ while (j < particlesLength && (particle = particles[j]).particleIndex == i) {
+ for (k = 0; k < mesh.subMeshes.length; k++) {
+ subMesh = mesh.subMeshes[k];
+ if (subMesh.subGeometry == particle.subGeometry) {
+ animationSubGeometry = (mesh.shareAnimationGeometry) ? this._animationSubGeometries[subMesh.subGeometry.id] : this._animationSubGeometries[subMesh.id];
+ break;
+ }
+ }
+ numVertices = particle.numVertices;
+ vertexData = animationSubGeometry.vertexData;
+ vertexLength = numVertices * this._totalLenOfOneVertex;
+ startingOffset = animationSubGeometry.numProcessedVertices * this._totalLenOfOneVertex;
+ for (k = 0; k < this._localStaticNodes.length; k++) {
+ localNode = this._localStaticNodes[k];
+ oneData = localNode.oneData;
+ oneDataLen = localNode.dataLength;
+ oneDataOffset = startingOffset + localNode._iDataOffset;
+ for (counterForVertex = 0; counterForVertex < vertexLength; counterForVertex += this._totalLenOfOneVertex) {
+ vertexOffset = oneDataOffset + counterForVertex;
+ for (counterForOneData = 0; counterForOneData < oneDataLen; counterForOneData++)
+ vertexData[vertexOffset + counterForOneData] = oneData[counterForOneData];
+ }
+ }
+ //store particle properties if they need to be retreived for dynamic local nodes
+ if (this._localDynamicNodes.length)
+ animationSubGeometry.animationParticles.push(new ParticleAnimationData(i, particleProperties.startTime, particleProperties.duration, particleProperties.delay, particle));
+ animationSubGeometry.numProcessedVertices += numVertices;
+ //next index
+ j++;
+ }
+ //next particle
+ i++;
+ }
+ };
+ /**
+ * Property used by particle nodes that require compilation at the end of the shader
+ */
+ ParticleAnimationSet.POST_PRIORITY = 9;
+ /**
+ * Property used by particle nodes that require color compilation
+ */
+ ParticleAnimationSet.COLOR_PRIORITY = 18;
+ return ParticleAnimationSet;
+})(AnimationSetBase);
+module.exports = ParticleAnimationSet;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/particleanimationset.ts"],"names":["ParticleAnimationSet","ParticleAnimationSet.constructor","ParticleAnimationSet.particleNodes","ParticleAnimationSet.addAnimation","ParticleAnimationSet.activate","ParticleAnimationSet.deactivate","ParticleAnimationSet.getAGALVertexCode","ParticleAnimationSet.getAGALUVCode","ParticleAnimationSet.getAGALFragmentCode","ParticleAnimationSet.doneAGALCode","ParticleAnimationSet.usesCPU","ParticleAnimationSet.cancelGPUCompatibility","ParticleAnimationSet.dispose","ParticleAnimationSet.getAnimationSubGeometry","ParticleAnimationSet._iGenerateAnimationSubGeometries"],"mappings":";;;;;;AAMA,IAAO,gBAAgB,WAAe,+CAA+C,CAAC,CAAC;AAEvF,IAAO,sBAAsB,WAAa,0DAA0D,CAAC,CAAC;AAItG,IAAO,oBAAoB,WAAc,2DAA2D,CAAC,CAAC;AACtG,IAAO,qBAAqB,WAAa,4DAA4D,CAAC,CAAC;AACvG,IAAO,kBAAkB,WAAc,yDAAyD,CAAC,CAAC;AAClG,IAAO,sBAAsB,WAAa,6DAA6D,CAAC,CAAC;AAGzG,IAAO,gBAAgB,WAAe,wDAAwD,CAAC,CAAC;AAGhG,AAKA;;;;GADG;IACG,oBAAoB;IAASA,UAA7BA,oBAAoBA,UAAyBA;IAyDlDA;;;;;;OAMGA;IACHA,SAhEKA,oBAAoBA,CAgEbA,YAA4BA,EAAEA,WAA2BA,EAAEA,SAAyBA;QAApFC,4BAA4BA,GAA5BA,oBAA4BA;QAAEA,2BAA2BA,GAA3BA,mBAA2BA;QAAEA,yBAAyBA,GAAzBA,iBAAyBA;QAE/FA,iBAAOA,CAACA;QAhDDA,4BAAuBA,GAAUA,IAAIA,MAAMA,EAAEA,CAACA;QAC9CA,mBAAcA,GAA2BA,IAAIA,KAAKA,EAAoBA,CAACA;QACvEA,uBAAkBA,GAA2BA,IAAIA,KAAKA,EAAoBA,CAACA;QAC3EA,sBAAiBA,GAA2BA,IAAIA,KAAKA,EAAoBA,CAACA;QAC1EA,yBAAoBA,GAAkBA,CAACA,CAACA;QA8C/CA,AACAA,mDADmDA;QACnDA,IAAIA,CAACA,YAAYA,CAACA,IAAIA,CAACA,SAASA,GAAGA,IAAIA,gBAAgBA,CAACA,YAAYA,EAAEA,WAAWA,EAAEA,SAASA,CAACA,CAACA,CAACA;IAChGA,CAACA;IAKDD,sBAAWA,+CAAaA;QAHxBA;;WAEGA;aACHA;YAECE,MAAMA,CAACA,IAAIA,CAACA,cAAcA,CAACA;QAC5BA,CAACA;;;OAAAF;IAEDA;;OAEGA;IACIA,2CAAYA,GAAnBA,UAAoBA,IAAsBA;QAEzCG,IAAIA,CAACA,CAAQA,OAADA,AAAQA,CAACA;QACrBA,IAAIA,CAACA,GAAuCA,IAAIA,CAACA;QACjDA,CAACA,CAACA,yBAAyBA,CAACA,IAAIA,CAACA,CAACA;QAClCA,EAAEA,CAACA,CAACA,CAACA,CAACA,IAAIA,IAAIA,sBAAsBA,CAACA,YAAYA,CAACA,CAACA,CAACA;YACnDA,CAACA,CAACA,YAAYA,GAAGA,IAAIA,CAACA,oBAAoBA,CAACA;YAC3CA,IAAIA,CAACA,oBAAoBA,IAAIA,CAACA,CAACA,UAAUA,CAACA;YAC1CA,IAAIA,CAACA,iBAAiBA,CAACA,IAAIA,CAACA,CAACA,CAACA,CAACA;QAChCA,CAACA;QAACA,IAAIA,CAACA,EAAEA,CAACA,CAACA,CAACA,CAACA,IAAIA,IAAIA,sBAAsBA,CAACA,aAAaA,CAACA;YACzDA,IAAIA,CAACA,kBAAkBA,CAACA,IAAIA,CAACA,CAACA,CAACA,CAACA;QAEjCA,GAAGA,CAACA,CAACA,CAACA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,MAAMA,GAAGA,CAACA,EAAEA,CAACA,IAAIA,CAACA,EAAEA,CAACA,EAAEA,EAAEA,CAACA;YACtDA,EAAEA,CAACA,CAACA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA,QAAQA,IAAIA,CAACA,CAACA,QAAQA,CAACA;gBACjDA,KAAKA,CAACA;QACRA,CAACA;QAEDA,IAAIA,CAACA,cAAcA,CAACA,MAAMA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,EAAEA,CAACA,CAACA,CAACA;QAExCA,gBAAKA,CAACA,YAAYA,YAACA,IAAIA,CAACA,CAACA;IAC1BA,CAACA;IAEDH;;OAEGA;IACIA,uCAAQA,GAAfA,UAAgBA,YAA6BA,EAAEA,KAAWA;QAE3DI,iEAAiEA;IAChEA,CAACA;IAEDJ;;OAEGA;IACIA,yCAAUA,GAAjBA,UAAkBA,YAA6BA,EAAEA,KAAWA;QAE7DK,mEAAmEA;QACnEA,sFAAsFA;QACtFA,4EAA4EA;QAC5EA,uDAAuDA;QACvDA,yCAAyCA;IACxCA,CAACA;IAEDL;;OAEGA;IACIA,gDAAiBA,GAAxBA,UAAyBA,YAA6BA;QAErDM,AACAA,6FAD6FA;QAC7FA,IAAIA,CAACA,wBAAwBA,GAAGA,YAAYA,CAACA,sBAAsBA,CAACA;QAEpEA,EAAEA,CAACA,CAACA,IAAIA,CAACA,wBAAwBA,IAAIA,IAAIA,CAACA;YACzCA,IAAIA,CAACA,wBAAwBA,GAAGA,YAAYA,CAACA,sBAAsBA,GAAGA,IAAIA,sBAAsBA,CAACA,YAAYA,CAACA,OAAOA,CAACA,CAACA;QAExHA,AACAA,8BAD8BA;QAC9BA,IAAIA,CAACA,wBAAwBA,CAACA,oBAAoBA,GAAGA,YAAYA,CAACA,sBAAsBA,CAACA;QACzFA,IAAIA,CAACA,wBAAwBA,CAACA,sBAAsBA,GAAGA,YAAYA,CAACA,cAAcA,CAACA;QACnFA,IAAIA,CAACA,wBAAwBA,CAACA,cAAcA,GAAGA,YAAYA,CAACA,eAAeA,CAACA;QAC5EA,IAAIA,CAACA,wBAAwBA,CAACA,sBAAsBA,GAAGA,YAAYA,CAACA,wBAAwBA,CAACA;QAC7FA,IAAIA,CAACA,wBAAwBA,CAACA,SAASA,GAAGA,IAAIA,CAACA,SAASA,CAACA;QACzDA,IAAIA,CAACA,wBAAwBA,CAACA,YAAYA,GAAGA,IAAIA,CAACA,YAAYA,CAACA;QAC/DA,IAAIA,CAACA,wBAAwBA,CAACA,YAAYA,GAAGA,IAAIA,CAACA,YAAYA,CAACA;QAC/DA,IAAIA,CAACA,wBAAwBA,CAACA,eAAeA,GAAGA,YAAYA,CAACA,oBAAoBA,CAACA;QAClFA,IAAIA,CAACA,wBAAwBA,CAACA,eAAeA,GAAGA,YAAYA,CAACA,wBAAwBA,CAACA;QACtFA,IAAIA,CAACA,wBAAwBA,CAACA,qBAAqBA,GAAGA,YAAYA,CAACA,qBAAqBA,CAACA;QACzFA,IAAIA,CAACA,wBAAwBA,CAACA,eAAeA,GAAGA,CAACA,YAAYA,CAACA,eAAeA,CAACA;QAC9EA,IAAIA,CAACA,wBAAwBA,CAACA,eAAeA,GAAGA,IAAIA,CAACA,eAAeA,CAACA;QACrEA,IAAIA,CAACA,wBAAwBA,CAACA,eAAeA,GAAGA,IAAIA,CAACA,eAAeA,CAACA;QACrEA,IAAIA,CAACA,wBAAwBA,CAACA,KAAKA,EAAEA,CAACA;QAEtCA,IAAIA,IAAIA,GAAUA,EAAEA,CAACA;QAErBA,IAAIA,IAAIA,IAAIA,CAACA,wBAAwBA,CAACA,WAAWA,EAAEA,CAACA;QAEpDA,IAAIA,IAAqBA,CAACA;QAC1BA,IAAIA,CAACA,CAAQA,OAADA,AAAQA,CAACA;QAErBA,GAAGA,CAACA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,MAAMA,EAAEA,CAACA,EAAEA,EAAEA,CAACA;YACjDA,IAAIA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA;YAC9BA,EAAEA,CAACA,CAACA,IAAIA,CAACA,QAAQA,GAAGA,oBAAoBA,CAACA,aAAaA,CAACA;gBACtDA,IAAIA,IAAIA,IAAIA,CAACA,iBAAiBA,CAACA,YAAYA,EAAEA,IAAIA,CAACA,wBAAwBA,CAACA,CAACA;QAC9EA,CAACA;QAEDA,IAAIA,IAAIA,IAAIA,CAACA,wBAAwBA,CAACA,kBAAkBA,EAAEA,CAACA;QAE3DA,GAAGA,CAACA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,MAAMA,EAAEA,CAACA,EAAEA,EAAEA,CAACA;YACjDA,IAAIA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA;YAC9BA,EAAEA,CAACA,CAACA,IAAIA,CAACA,QAAQA,IAAIA,oBAAoBA,CAACA,aAAaA,IAAIA,IAAIA,CAACA,QAAQA,GAAGA,oBAAoBA,CAACA,cAAcA,CAACA;gBAC9GA,IAAIA,IAAIA,IAAIA,CAACA,iBAAiBA,CAACA,YAAYA,EAAEA,IAAIA,CAACA,wBAAwBA,CAACA,CAACA;QAC9EA,CAACA;QAEDA,IAAIA,IAAIA,IAAIA,CAACA,wBAAwBA,CAACA,kBAAkBA,EAAEA,CAACA;QAE3DA,GAAGA,CAACA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,MAAMA,EAAEA,CAACA,EAAEA,EAAEA,CAACA;YACjDA,IAAIA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA;YAC9BA,EAAEA,CAACA,CAACA,IAAIA,CAACA,QAAQA,IAAIA,oBAAoBA,CAACA,cAAcA,CAACA;gBACxDA,IAAIA,IAAIA,IAAIA,CAACA,iBAAiBA,CAACA,YAAYA,EAAEA,IAAIA,CAACA,wBAAwBA,CAACA,CAACA;QAC9EA,CAACA;QACDA,IAAIA,IAAIA,IAAIA,CAACA,wBAAwBA,CAACA,gBAAgBA,EAAEA,CAACA;QACzDA,MAAMA,CAACA,IAAIA,CAACA;IACbA,CAACA;IAEDN;;OAEGA;IACIA,4CAAaA,GAApBA,UAAqBA,YAA6BA;QAEjDO,IAAIA,IAAIA,GAAUA,EAAEA,CAACA;QACrBA,EAAEA,CAACA,CAACA,IAAIA,CAACA,SAASA,CAACA,CAACA,CAACA;YACpBA,IAAIA,CAACA,wBAAwBA,CAACA,oBAAoBA,CAACA,YAAYA,CAACA,QAAQA,EAAEA,YAAYA,CAACA,QAAQA,CAACA,CAACA;YACjGA,IAAIA,IAAIA,MAAMA,GAAGA,IAAIA,CAACA,wBAAwBA,CAACA,QAAQA,GAAGA,MAAMA,GAAGA,IAAIA,CAACA,wBAAwBA,CAACA,WAAWA,CAACA,QAAQA,EAAEA,GAAGA,IAAIA,CAACA;YAC/HA,IAAIA,IAAqBA,CAACA;YAC1BA,GAAGA,CAACA,CAACA,GAAGA,CAACA,CAACA,GAAmBA,CAACA,EAAEA,CAACA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,MAAMA,EAAEA,CAACA,EAAEA;gBAClEA,IAAIA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA;YAC9BA,IAAIA,IAAIA,IAAIA,CAACA,aAAaA,CAACA,YAAYA,EAAEA,IAAIA,CAACA,wBAAwBA,CAACA,CAACA;YACzEA,IAAIA,IAAIA,MAAMA,GAAGA,IAAIA,CAACA,wBAAwBA,CAACA,KAAKA,CAACA,QAAQA,EAAEA,GAAGA,GAAGA,GAAGA,IAAIA,CAACA,wBAAwBA,CAACA,QAAQA,GAAGA,OAAOA,CAACA;QAC1HA,CAACA;QAACA,IAAIA;YACLA,IAAIA,IAAIA,MAAMA,GAAGA,YAAYA,CAACA,QAAQA,GAAGA,GAAGA,GAAGA,YAAYA,CAACA,QAAQA,GAAGA,IAAIA,CAACA;QAC7EA,MAAMA,CAACA,IAAIA,CAACA;IACbA,CAACA;IAEDP;;OAEGA;IACIA,kDAAmBA,GAA1BA,UAA2BA,YAA6BA,EAAEA,YAAmBA;QAE5EQ,MAAMA,CAACA,IAAIA,CAACA,wBAAwBA,CAACA,uBAAuBA,CAACA,YAAYA,CAACA,CAACA;IAC5EA,CAACA;IAEDR;;OAEGA;IACIA,2CAAYA,GAAnBA,UAAoBA,YAA6BA;QAEhDS,IAAIA,CAACA,wBAAwBA,CAACA,aAAaA,EAAEA,CAACA;QAE9CA,AACAA,mDADmDA;QACnDA,IAAIA,CAACA,wBAAwBA,CAACA,cAAcA,CAACA,IAAIA,CAACA,wBAAwBA,CAACA,eAAeA,CAACA,KAAKA,EAAEA,CAACA,EAAEA,CAACA,EAAEA,CAACA,EAAEA,CAACA,CAACA,CAACA;IAC/GA,CAACA;IAKDT,sBAAWA,yCAAOA;QAHlBA;;WAEGA;aACHA;YAECU,MAAMA,CAACA,KAAKA,CAACA;QACdA,CAACA;;;OAAAV;IAEDA;;OAEGA;IACIA,qDAAsBA,GAA7BA;IAGAW,CAACA;IAEMX,sCAAOA,GAAdA;QAECY,GAAGA,CAACA,CAACA,GAAGA,CAACA,GAAGA,IAAIA,IAAIA,CAACA,uBAAuBA,CAACA;YACpBA,IAAIA,CAACA,uBAAuBA,CAACA,GAAGA,CAAEA,CAACA,OAAOA,EAAEA,CAACA;QAEtEA,gBAAKA,CAACA,OAAOA,WAAEA,CAACA;IACjBA,CAACA;IAEMZ,sDAAuBA,GAA9BA,UAA+BA,OAAgBA;QAE9Ca,IAAIA,IAAIA,GAAQA,OAAOA,CAACA,UAAUA,CAACA;QACnCA,IAAIA,oBAAoBA,GAAwBA,CAACA,IAAIA,CAACA,sBAAsBA,CAACA,GAAEA,IAAIA,CAACA,uBAAuBA,CAACA,OAAOA,CAACA,WAAWA,CAACA,EAAEA,CAACA,GAAGA,IAAIA,CAACA,uBAAuBA,CAACA,OAAOA,CAACA,EAAEA,CAACA,CAACA;QAE/KA,EAAEA,CAACA,CAACA,oBAAoBA,CAACA;YACxBA,MAAMA,CAACA,oBAAoBA,CAACA;QAE7BA,IAAIA,CAACA,gCAAgCA,CAACA,IAAIA,CAACA,CAACA;QAE5CA,MAAMA,CAACA,CAACA,IAAIA,CAACA,sBAAsBA,CAACA,GAAEA,IAAIA,CAACA,uBAAuBA,CAACA,OAAOA,CAACA,WAAWA,CAACA,EAAEA,CAACA,GAAGA,IAAIA,CAACA,uBAAuBA,CAACA,OAAOA,CAACA,EAAEA,CAACA,CAACA;IACvIA,CAACA;IAGDb,eAAeA;IACRA,+DAAgCA,GAAvCA,UAAwCA,IAASA;QAEhDc,EAAEA,CAACA,CAACA,IAAIA,CAACA,gBAAgBA,IAAIA,IAAIA,CAACA;YACjCA,MAAKA,CAACA,IAAIA,KAAKA,CAACA,yBAAyBA,CAACA,CAACA,CAACA;QAE7CA,IAAIA,QAAQA,GAAuCA,IAAIA,CAACA,QAAQA,CAACA;QAEjEA,EAAEA,CAACA,CAACA,CAACA,QAAQA,CAACA;YACbA,MAAKA,CAACA,IAAIA,KAAKA,CAACA,uEAAuEA,CAACA,CAACA,CAACA;QAE3FA,IAAIA,CAACA,CAAQA,OAADA,AAAQA,EAAEA,CAACA,CAAQA,OAADA,AAAQA,EAAEA,CAACA,CAAQA,OAADA,AAAQA,CAACA;QACzDA,IAAIA,oBAAyCA,CAACA;QAC9CA,IAAIA,uBAAuBA,GAAWA,KAAKA,CAACA;QAC5CA,IAAIA,WAA2BA,CAACA;QAChCA,IAAIA,OAAgBA,CAACA;QACrBA,IAAIA,SAA0BA,CAACA;QAE/BA,GAAGA,CAACA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,GAAGA,IAAIA,CAACA,SAASA,CAACA,MAAMA,EAAEA,CAACA,EAAEA,EAAEA,CAACA;YAC5CA,OAAOA,GAAGA,IAAIA,CAACA,SAASA,CAACA,CAACA,CAACA,CAACA;YAC5BA,WAAWA,GAAGA,OAAOA,CAACA,WAAWA,CAACA;YAClCA,EAAEA,CAACA,CAACA,IAAIA,CAACA,sBAAsBA,CAACA,CAACA,CAACA;gBACjCA,oBAAoBA,GAAGA,IAAIA,CAACA,uBAAuBA,CAACA,WAAWA,CAACA,EAAEA,CAACA,CAACA;gBAEpEA,EAAEA,CAACA,CAACA,oBAAoBA,CAACA;oBACxBA,QAAQA,CAACA;YACXA,CAACA;YAEDA,oBAAoBA,GAAGA,IAAIA,oBAAoBA,EAAEA,CAACA;YAElDA,EAAEA,CAACA,CAACA,IAAIA,CAACA,sBAAsBA,CAACA;gBAC/BA,IAAIA,CAACA,uBAAuBA,CAACA,WAAWA,CAACA,EAAEA,CAACA,GAAGA,oBAAoBA,CAACA;YACrEA,IAAIA;gBACHA,IAAIA,CAACA,uBAAuBA,CAACA,OAAOA,CAACA,EAAEA,CAACA,GAAGA,oBAAoBA,CAACA;YAEjEA,uBAAuBA,GAAGA,IAAIA,CAACA;YAE/BA,AACAA,oEADoEA;YACpEA,oBAAoBA,CAACA,gBAAgBA,CAACA,WAAWA,CAACA,WAAWA,EAAEA,IAAIA,CAACA,oBAAoBA,CAACA,CAACA;QAC3FA,CAACA;QAEDA,EAAEA,CAACA,CAACA,CAACA,uBAAuBA,CAACA;YAC5BA,MAAMA,CAACA;QAERA,IAAIA,SAASA,GAAuBA,QAAQA,CAACA,SAASA,CAACA;QACvDA,IAAIA,eAAeA,GAAmBA,SAASA,CAACA,MAAMA,CAACA;QACvDA,IAAIA,YAAYA,GAAmBA,QAAQA,CAACA,YAAYA,CAACA;QACzDA,IAAIA,kBAAkBA,GAAsBA,IAAIA,kBAAkBA,EAAEA,CAACA;QACrEA,IAAIA,QAAqBA,CAACA;QAE1BA,IAAIA,UAAUA,CAAQA,OAADA,AAAQA,CAACA;QAC9BA,IAAIA,aAAaA,CAAQA,OAADA,AAAQA,CAACA;QACjCA,IAAIA,gBAAgBA,CAAQA,OAADA,AAAQA,CAACA;QACpCA,IAAIA,iBAAiBA,CAAQA,OAADA,AAAQA,CAACA;QACrCA,IAAIA,OAAqBA,CAACA;QAC1BA,IAAIA,WAAWA,CAAQA,QAADA,AAASA,CAACA;QAChCA,IAAIA,UAAwBA,CAACA;QAC7BA,IAAIA,YAAYA,CAAQA,QAADA,AAASA,CAACA;QACjCA,IAAIA,cAAcA,CAAQA,QAADA,AAASA,CAACA;QACnCA,IAAIA,YAAYA,CAAQA,QAADA,AAASA,CAACA;QAEjCA,AACAA,mCADmCA;QACnCA,kBAAkBA,CAACA,KAAKA,GAAGA,YAAYA,CAACA;QACxCA,kBAAkBA,CAACA,SAASA,GAAGA,CAACA,CAACA;QACjCA,kBAAkBA,CAACA,QAAQA,GAAGA,IAAIA,CAACA;QACnCA,kBAAkBA,CAACA,KAAKA,GAAGA,GAAGA,CAACA;QAE/BA,CAACA,GAAGA,CAACA,CAACA;QACNA,CAACA,GAAGA,CAACA,CAACA;QACNA,OAAOA,CAACA,GAAGA,YAAYA,EAAEA,CAACA;YACzBA,kBAAkBA,CAACA,KAAKA,GAAGA,CAACA,CAACA;YAE7BA,AACAA,0CAD0CA;YAC1CA,IAAIA,CAACA,gBAAgBA,CAACA,IAAIA,CAACA,IAAIA,CAACA,iBAAiBA,EAAEA,kBAAkBA,CAACA,CAACA;YAGvEA,GAAGA,CAACA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,GAAGA,IAAIA,CAACA,iBAAiBA,CAACA,MAAMA,EAAEA,CAACA,EAAEA;gBACjDA,IAAIA,CAACA,iBAAiBA,CAACA,CAACA,CAACA,CAACA,+BAA+BA,CAACA,kBAAkBA,CAACA,CAACA;YAG/EA,OAAOA,CAACA,GAAGA,eAAeA,IAAIA,CAACA,QAAQA,GAAGA,SAASA,CAACA,CAACA,CAACA,CAACA,CAACA,aAAaA,IAAIA,CAACA,EAAEA,CAACA;gBAE5EA,GAAGA,CAACA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,GAAGA,IAAIA,CAACA,SAASA,CAACA,MAAMA,EAAEA,CAACA,EAAEA,EAAEA,CAACA;oBAC5CA,OAAOA,GAAGA,IAAIA,CAACA,SAASA,CAACA,CAACA,CAACA,CAACA;oBAC5BA,EAAEA,CAACA,CAACA,OAAOA,CAACA,WAAWA,IAAIA,QAAQA,CAACA,WAAWA,CAACA,CAACA,CAACA;wBACjDA,oBAAoBA,GAAGA,CAACA,IAAIA,CAACA,sBAAsBA,CAACA,GAAEA,IAAIA,CAACA,uBAAuBA,CAACA,OAAOA,CAACA,WAAWA,CAACA,EAAEA,CAACA,GAAGA,IAAIA,CAACA,uBAAuBA,CAACA,OAAOA,CAACA,EAAEA,CAACA,CAACA;wBACtJA,KAAKA,CAACA;oBACPA,CAACA;gBACFA,CAACA;gBACDA,WAAWA,GAAGA,QAAQA,CAACA,WAAWA,CAACA;gBACnCA,UAAUA,GAAGA,oBAAoBA,CAACA,UAAUA,CAACA;gBAC7CA,YAAYA,GAAGA,WAAWA,GAACA,IAAIA,CAACA,oBAAoBA,CAACA;gBACrDA,cAAcA,GAAGA,oBAAoBA,CAACA,oBAAoBA,GAACA,IAAIA,CAACA,oBAAoBA,CAACA;gBAGrFA,GAAGA,CAACA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,GAAGA,IAAIA,CAACA,iBAAiBA,CAACA,MAAMA,EAAEA,CAACA,EAAEA,EAAEA,CAACA;oBACpDA,SAASA,GAAGA,IAAIA,CAACA,iBAAiBA,CAACA,CAACA,CAACA,CAACA;oBACtCA,OAAOA,GAAGA,SAASA,CAACA,OAAOA,CAACA;oBAC5BA,UAAUA,GAAGA,SAASA,CAACA,UAAUA,CAACA;oBAClCA,aAAaA,GAAGA,cAAcA,GAAGA,SAASA,CAACA,YAAYA,CAACA;oBAGxDA,GAAGA,CAACA,CAACA,gBAAgBA,GAAGA,CAACA,EAAEA,gBAAgBA,GAAGA,YAAYA,EAAEA,gBAAgBA,IAAIA,IAAIA,CAACA,oBAAoBA,EAAEA,CAACA;wBAC3GA,YAAYA,GAAGA,aAAaA,GAAGA,gBAAgBA,CAACA;wBAGhDA,GAAGA,CAACA,CAACA,iBAAiBA,GAAGA,CAACA,EAAEA,iBAAiBA,GAAGA,UAAUA,EAAEA,iBAAiBA,EAAEA;4BAC9EA,UAAUA,CAACA,YAAYA,GAAGA,iBAAiBA,CAACA,GAAGA,OAAOA,CAACA,iBAAiBA,CAACA,CAACA;oBAC5EA,CAACA;gBAEFA,CAACA;gBAEDA,AACAA,gFADgFA;gBAChFA,EAAEA,CAACA,CAACA,IAAIA,CAACA,kBAAkBA,CAACA,MAAMA,CAACA;oBAClCA,oBAAoBA,CAACA,kBAAkBA,CAACA,IAAIA,CAACA,IAAIA,qBAAqBA,CAACA,CAACA,EAAEA,kBAAkBA,CAACA,SAASA,EAAEA,kBAAkBA,CAACA,QAAQA,EAAEA,kBAAkBA,CAACA,KAAKA,EAAEA,QAAQA,CAACA,CAACA,CAACA;gBAE3KA,oBAAoBA,CAACA,oBAAoBA,IAAIA,WAAWA,CAACA;gBAEzDA,AACAA,YADYA;gBACZA,CAACA,EAAEA,CAACA;YACLA,CAACA;YAEDA,AACAA,eADeA;YACfA,CAACA,EAAEA,CAACA;QACLA,CAACA;IACFA,CAACA;IAzXDd;;OAEGA;IACWA,kCAAaA,GAAkBA,CAACA,CAACA;IAE/CA;;OAEGA;IACWA,mCAAcA,GAAkBA,EAAEA,CAACA;IAkXlDA,2BAACA;AAADA,CAlYA,AAkYCA,EAlYkC,gBAAgB,EAkYlD;AAED,AAA8B,iBAArB,oBAAoB,CAAC","file":"animators/ParticleAnimationSet.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import IAnimationSet\t\t\t\t\t= require(\"awayjs-core/lib/animators/IAnimationSet\");\nimport AnimationNodeBase\t\t\t\t= require(\"awayjs-core/lib/animators/nodes/AnimationNodeBase\");\nimport ISubMesh\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/base/ISubMesh\");\nimport SubGeometryBase\t\t\t\t\t= require(\"awayjs-core/lib/core/base/SubGeometryBase\");\nimport Mesh\t\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Mesh\");\n\nimport AnimationSetBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimationSetBase\");\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\n\nimport AnimationSubGeometry\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/AnimationSubGeometry\");\nimport ParticleAnimationData\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleAnimationData\");\nimport ParticleProperties\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleProperties\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleData\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleData\");\nimport ParticleNodeBase\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleNodeBase\");\nimport ParticleTimeNode\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleTimeNode\");\nimport ParticleGeometry\t\t\t\t\t= require(\"awayjs-renderergl/lib/core/base/ParticleGeometry\");\n\n/**\n * The animation data set used by particle-based animators, containing particle animation data.\n *\n * @see away.animators.ParticleAnimator\n */\nclass ParticleAnimationSet extends AnimationSetBase implements IAnimationSet\n{\n\t/** @private */\n\tpublic _iAnimationRegisterCache:AnimationRegisterCache;\n\n\t//all other nodes dependent on it\n\tprivate _timeNode:ParticleTimeNode;\n\n\t/**\n\t * Property used by particle nodes that require compilation at the end of the shader\n\t */\n\tpublic static POST_PRIORITY:number /*int*/ = 9;\n\n\t/**\n\t * Property used by particle nodes that require color compilation\n\t */\n\tpublic static COLOR_PRIORITY:number /*int*/ = 18;\n\n\tprivate _animationSubGeometries:Object = new Object();\n\tprivate _particleNodes:Array<ParticleNodeBase> = new Array<ParticleNodeBase>();\n\tprivate _localDynamicNodes:Array<ParticleNodeBase> = new Array<ParticleNodeBase>();\n\tprivate _localStaticNodes:Array<ParticleNodeBase> = new Array<ParticleNodeBase>();\n\tprivate _totalLenOfOneVertex:number /*int*/ = 0;\n\n\t//set true if has an node which will change UV\n\tpublic hasUVNode:boolean;\n\t//set if the other nodes need to access the velocity\n\tpublic needVelocity:boolean;\n\t//set if has a billboard node.\n\tpublic hasBillboard:boolean;\n\t//set if has an node which will apply color multiple operation\n\tpublic hasColorMulNode:boolean;\n\t//set if has an node which will apply color add operation\n\tpublic hasColorAddNode:boolean;\n\n\t/**\n\t * Initialiser function for static particle properties. Needs to reference a with the following format\n\t *\n\t * <code>\n\t * initParticleFunc(prop:ParticleProperties)\n\t * {\n\t * \t\t//code for settings local properties\n\t * }\n\t * </code>\n\t *\n\t * Aside from setting any properties required in particle animation nodes using local static properties, the initParticleFunc function\n\t * is required to time node requirements as they may be needed. These properties on the ParticleProperties object can include\n\t * <code>startTime</code>, <code>duration</code> and <code>delay</code>. The use of these properties is determined by the setting\n\t * arguments passed in the constructor of the particle animation set. By default, only the <code>startTime</code> property is required.\n\t */\n\tpublic initParticleFunc:Function;\n\n\t/**\n\t * Initialiser function scope for static particle properties\n\t */\n\tpublic initParticleScope:Object;\n\n\t/**\n\t * Creates a new <code>ParticleAnimationSet</code>\n\t *\n\t * @param    [optional] usesDuration    Defines whether the animation set uses the <code>duration</code> data in its static properties to determine how long a particle is visible for. Defaults to false.\n\t * @param    [optional] usesLooping     Defines whether the animation set uses a looping timeframe for each particle determined by the <code>startTime</code>, <code>duration</code> and <code>delay</code> data in its static properties function. Defaults to false. Requires <code>usesDuration</code> to be true.\n\t * @param    [optional] usesDelay       Defines whether the animation set uses the <code>delay</code> data in its static properties to determine how long a particle is hidden for. Defaults to false. Requires <code>usesLooping</code> to be true.\n\t */\n\tconstructor(usesDuration:boolean = false, usesLooping:boolean = false, usesDelay:boolean = false)\n\t{\n\t\tsuper();\n\n\t\t//automatically add a particle time node to the set\n\t\tthis.addAnimation(this._timeNode = new ParticleTimeNode(usesDuration, usesLooping, usesDelay));\n\t}\n\n\t/**\n\t * Returns a vector of the particle animation nodes contained within the set.\n\t */\n\tpublic get particleNodes():Array<ParticleNodeBase>\n\t{\n\t\treturn this._particleNodes;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic addAnimation(node:AnimationNodeBase)\n\t{\n\t\tvar i:number /*int*/;\n\t\tvar n:ParticleNodeBase = <ParticleNodeBase> node;\n\t\tn._iProcessAnimationSetting(this);\n\t\tif (n.mode == ParticlePropertiesMode.LOCAL_STATIC) {\n\t\t\tn._iDataOffset = this._totalLenOfOneVertex;\n\t\t\tthis._totalLenOfOneVertex += n.dataLength;\n\t\t\tthis._localStaticNodes.push(n);\n\t\t} else if (n.mode == ParticlePropertiesMode.LOCAL_DYNAMIC)\n\t\t\tthis._localDynamicNodes.push(n);\n\n\t\tfor (i = this._particleNodes.length - 1; i >= 0; i--) {\n\t\t\tif (this._particleNodes[i].priority <= n.priority)\n\t\t\t\tbreak;\n\t\t}\n\n\t\tthis._particleNodes.splice(i + 1, 0, n);\n\n\t\tsuper.addAnimation(node);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic activate(shaderObject:ShaderObjectBase, stage:Stage)\n\t{\n//\t\t\tthis._iAnimationRegisterCache = pass.animationRegisterCache;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic deactivate(shaderObject:ShaderObjectBase, stage:Stage)\n\t{\n//\t\t\tvar context:IContextStageGL = <IContextStageGL> stage.context;\n//\t\t\tvar offset:number /*int*/ = this._iAnimationRegisterCache.vertexAttributesOffset;\n//\t\t\tvar used:number /*int*/ = this._iAnimationRegisterCache.numUsedStreams;\n//\t\t\tfor (var i:number /*int*/ = offset; i < used; i++)\n//\t\t\t\tcontext.setVertexBufferAt(i, null);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALVertexCode(shaderObject:ShaderObjectBase):string\n\t{\n\t\t//grab animationRegisterCache from the materialpassbase or create a new one if the first time\n\t\tthis._iAnimationRegisterCache = shaderObject.animationRegisterCache;\n\n\t\tif (this._iAnimationRegisterCache == null)\n\t\t\tthis._iAnimationRegisterCache = shaderObject.animationRegisterCache = new AnimationRegisterCache(shaderObject.profile);\n\n\t\t//reset animationRegisterCache\n\t\tthis._iAnimationRegisterCache.vertexConstantOffset = shaderObject.numUsedVertexConstants;\n\t\tthis._iAnimationRegisterCache.vertexAttributesOffset = shaderObject.numUsedStreams;\n\t\tthis._iAnimationRegisterCache.varyingsOffset = shaderObject.numUsedVaryings;\n\t\tthis._iAnimationRegisterCache.fragmentConstantOffset = shaderObject.numUsedFragmentConstants;\n\t\tthis._iAnimationRegisterCache.hasUVNode = this.hasUVNode;\n\t\tthis._iAnimationRegisterCache.needVelocity = this.needVelocity;\n\t\tthis._iAnimationRegisterCache.hasBillboard = this.hasBillboard;\n\t\tthis._iAnimationRegisterCache.sourceRegisters = shaderObject.animatableAttributes;\n\t\tthis._iAnimationRegisterCache.targetRegisters = shaderObject.animationTargetRegisters;\n\t\tthis._iAnimationRegisterCache.needFragmentAnimation = shaderObject.usesFragmentAnimation;\n\t\tthis._iAnimationRegisterCache.needUVAnimation = !shaderObject.usesUVTransform;\n\t\tthis._iAnimationRegisterCache.hasColorAddNode = this.hasColorAddNode;\n\t\tthis._iAnimationRegisterCache.hasColorMulNode = this.hasColorMulNode;\n\t\tthis._iAnimationRegisterCache.reset();\n\n\t\tvar code:string = \"\";\n\n\t\tcode += this._iAnimationRegisterCache.getInitCode();\n\n\t\tvar node:ParticleNodeBase;\n\t\tvar i:number /*int*/;\n\n\t\tfor (i = 0; i < this._particleNodes.length; i++) {\n\t\t\tnode = this._particleNodes[i];\n\t\t\tif (node.priority < ParticleAnimationSet.POST_PRIORITY)\n\t\t\t\tcode += node.getAGALVertexCode(shaderObject, this._iAnimationRegisterCache);\n\t\t}\n\n\t\tcode += this._iAnimationRegisterCache.getCombinationCode();\n\n\t\tfor (i = 0; i < this._particleNodes.length; i++) {\n\t\t\tnode = this._particleNodes[i];\n\t\t\tif (node.priority >= ParticleAnimationSet.POST_PRIORITY && node.priority < ParticleAnimationSet.COLOR_PRIORITY)\n\t\t\t\tcode += node.getAGALVertexCode(shaderObject, this._iAnimationRegisterCache);\n\t\t}\n\n\t\tcode += this._iAnimationRegisterCache.initColorRegisters();\n\n\t\tfor (i = 0; i < this._particleNodes.length; i++) {\n\t\t\tnode = this._particleNodes[i];\n\t\t\tif (node.priority >= ParticleAnimationSet.COLOR_PRIORITY)\n\t\t\t\tcode += node.getAGALVertexCode(shaderObject, this._iAnimationRegisterCache);\n\t\t}\n\t\tcode += this._iAnimationRegisterCache.getColorPassCode();\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALUVCode(shaderObject:ShaderObjectBase):string\n\t{\n\t\tvar code:string = \"\";\n\t\tif (this.hasUVNode) {\n\t\t\tthis._iAnimationRegisterCache.setUVSourceAndTarget(shaderObject.uvSource, shaderObject.uvTarget);\n\t\t\tcode += \"mov \" + this._iAnimationRegisterCache.uvTarget + \".xy,\" + this._iAnimationRegisterCache.uvAttribute.toString() + \"\\n\";\n\t\t\tvar node:ParticleNodeBase;\n\t\t\tfor (var i:number /*uint*/ = 0; i < this._particleNodes.length; i++)\n\t\t\t\tnode = this._particleNodes[i];\n\t\t\t\tcode += node.getAGALUVCode(shaderObject, this._iAnimationRegisterCache);\n\t\t\tcode += \"mov \" + this._iAnimationRegisterCache.uvVar.toString() + \",\" + this._iAnimationRegisterCache.uvTarget + \".xy\\n\";\n\t\t} else\n\t\t\tcode += \"mov \" + shaderObject.uvTarget + \",\" + shaderObject.uvSource + \"\\n\";\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALFragmentCode(shaderObject:ShaderObjectBase, shadedTarget:string):string\n\t{\n\t\treturn this._iAnimationRegisterCache.getColorCombinationCode(shadedTarget);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic doneAGALCode(shaderObject:ShaderObjectBase)\n\t{\n\t\tthis._iAnimationRegisterCache.setDataLength();\n\n\t\t//set vertexZeroConst,vertexOneConst,vertexTwoConst\n\t\tthis._iAnimationRegisterCache.setVertexConst(this._iAnimationRegisterCache.vertexZeroConst.index, 0, 1, 2, 0);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic get usesCPU():boolean\n\t{\n\t\treturn false;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic cancelGPUCompatibility()\n\t{\n\n\t}\n\n\tpublic dispose()\n\t{\n\t\tfor (var key in this._animationSubGeometries)\n\t\t\t(<AnimationSubGeometry> this._animationSubGeometries[key]).dispose();\n\n\t\tsuper.dispose();\n\t}\n\n\tpublic getAnimationSubGeometry(subMesh:ISubMesh)\n\t{\n\t\tvar mesh:Mesh = subMesh.parentMesh;\n\t\tvar animationSubGeometry:AnimationSubGeometry = (mesh.shareAnimationGeometry)? this._animationSubGeometries[subMesh.subGeometry.id] : this._animationSubGeometries[subMesh.id];\n\n\t\tif (animationSubGeometry)\n\t\t\treturn animationSubGeometry;\n\n\t\tthis._iGenerateAnimationSubGeometries(mesh);\n\n\t\treturn (mesh.shareAnimationGeometry)? this._animationSubGeometries[subMesh.subGeometry.id] : this._animationSubGeometries[subMesh.id];\n\t}\n\n\n\t/** @private */\n\tpublic _iGenerateAnimationSubGeometries(mesh:Mesh)\n\t{\n\t\tif (this.initParticleFunc == null)\n\t\t\tthrow(new Error(\"no initParticleFunc set\"));\n\n\t\tvar geometry:ParticleGeometry = <ParticleGeometry> mesh.geometry;\n\n\t\tif (!geometry)\n\t\t\tthrow(new Error(\"Particle animation can only be performed on a ParticleGeometry object\"));\n\n\t\tvar i:number /*int*/, j:number /*int*/, k:number /*int*/;\n\t\tvar animationSubGeometry:AnimationSubGeometry;\n\t\tvar newAnimationSubGeometry:boolean = false;\n\t\tvar subGeometry:SubGeometryBase;\n\t\tvar subMesh:ISubMesh;\n\t\tvar localNode:ParticleNodeBase;\n\n\t\tfor (i = 0; i < mesh.subMeshes.length; i++) {\n\t\t\tsubMesh = mesh.subMeshes[i];\n\t\t\tsubGeometry = subMesh.subGeometry;\n\t\t\tif (mesh.shareAnimationGeometry) {\n\t\t\t\tanimationSubGeometry = this._animationSubGeometries[subGeometry.id];\n\n\t\t\t\tif (animationSubGeometry)\n\t\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tanimationSubGeometry = new AnimationSubGeometry();\n\n\t\t\tif (mesh.shareAnimationGeometry)\n\t\t\t\tthis._animationSubGeometries[subGeometry.id] = animationSubGeometry;\n\t\t\telse\n\t\t\t\tthis._animationSubGeometries[subMesh.id] = animationSubGeometry;\n\n\t\t\tnewAnimationSubGeometry = true;\n\n\t\t\t//create the vertexData vector that will be used for local node data\n\t\t\tanimationSubGeometry.createVertexData(subGeometry.numVertices, this._totalLenOfOneVertex);\n\t\t}\n\n\t\tif (!newAnimationSubGeometry)\n\t\t\treturn;\n\n\t\tvar particles:Array<ParticleData> = geometry.particles;\n\t\tvar particlesLength:number /*uint*/ = particles.length;\n\t\tvar numParticles:number /*uint*/ = geometry.numParticles;\n\t\tvar particleProperties:ParticleProperties = new ParticleProperties();\n\t\tvar particle:ParticleData;\n\n\t\tvar oneDataLen:number /*int*/;\n\t\tvar oneDataOffset:number /*int*/;\n\t\tvar counterForVertex:number /*int*/;\n\t\tvar counterForOneData:number /*int*/;\n\t\tvar oneData:Array<number>;\n\t\tvar numVertices:number /*uint*/;\n\t\tvar vertexData:Array<number>;\n\t\tvar vertexLength:number /*uint*/;\n\t\tvar startingOffset:number /*uint*/;\n\t\tvar vertexOffset:number /*uint*/;\n\n\t\t//default values for particle param\n\t\tparticleProperties.total = numParticles;\n\t\tparticleProperties.startTime = 0;\n\t\tparticleProperties.duration = 1000;\n\t\tparticleProperties.delay = 0.1;\n\n\t\ti = 0;\n\t\tj = 0;\n\t\twhile (i < numParticles) {\n\t\t\tparticleProperties.index = i;\n\n\t\t\t//call the init on the particle parameters\n\t\t\tthis.initParticleFunc.call(this.initParticleScope, particleProperties);\n\n\t\t\t//create the next set of node properties for the particle\n\t\t\tfor (k = 0; k < this._localStaticNodes.length; k++)\n\t\t\t\tthis._localStaticNodes[k]._iGeneratePropertyOfOneParticle(particleProperties);\n\n\t\t\t//loop through all particle data for the curent particle\n\t\t\twhile (j < particlesLength && (particle = particles[j]).particleIndex == i) {\n\t\t\t\t//find the target animationSubGeometry\n\t\t\t\tfor (k = 0; k < mesh.subMeshes.length; k++) {\n\t\t\t\t\tsubMesh = mesh.subMeshes[k];\n\t\t\t\t\tif (subMesh.subGeometry == particle.subGeometry) {\n\t\t\t\t\t\tanimationSubGeometry = (mesh.shareAnimationGeometry)? this._animationSubGeometries[subMesh.subGeometry.id] : this._animationSubGeometries[subMesh.id];\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tnumVertices = particle.numVertices;\n\t\t\t\tvertexData = animationSubGeometry.vertexData;\n\t\t\t\tvertexLength = numVertices*this._totalLenOfOneVertex;\n\t\t\t\tstartingOffset = animationSubGeometry.numProcessedVertices*this._totalLenOfOneVertex;\n\n\t\t\t\t//loop through each static local node in the animation set\n\t\t\t\tfor (k = 0; k < this._localStaticNodes.length; k++) {\n\t\t\t\t\tlocalNode = this._localStaticNodes[k];\n\t\t\t\t\toneData = localNode.oneData;\n\t\t\t\t\toneDataLen = localNode.dataLength;\n\t\t\t\t\toneDataOffset = startingOffset + localNode._iDataOffset;\n\n\t\t\t\t\t//loop through each vertex set in the vertex data\n\t\t\t\t\tfor (counterForVertex = 0; counterForVertex < vertexLength; counterForVertex += this._totalLenOfOneVertex) {\n\t\t\t\t\t\tvertexOffset = oneDataOffset + counterForVertex;\n\n\t\t\t\t\t\t//add the data for the local node to the vertex data\n\t\t\t\t\t\tfor (counterForOneData = 0; counterForOneData < oneDataLen; counterForOneData++)\n\t\t\t\t\t\t\tvertexData[vertexOffset + counterForOneData] = oneData[counterForOneData];\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t\t//store particle properties if they need to be retreived for dynamic local nodes\n\t\t\t\tif (this._localDynamicNodes.length)\n\t\t\t\t\tanimationSubGeometry.animationParticles.push(new ParticleAnimationData(i, particleProperties.startTime, particleProperties.duration, particleProperties.delay, particle));\n\n\t\t\t\tanimationSubGeometry.numProcessedVertices += numVertices;\n\n\t\t\t\t//next index\n\t\t\t\tj++;\n\t\t\t}\n\n\t\t\t//next particle\n\t\t\ti++;\n\t\t}\n\t}\n}\n\nexport = ParticleAnimationSet;"]}
\ No newline at end of file
diff --git a/lib/animators/ParticleAnimationSet.ts b/lib/animators/ParticleAnimationSet.ts
new file mode 100644
index 000000000..d4d51f476
--- /dev/null
+++ b/lib/animators/ParticleAnimationSet.ts
@@ -0,0 +1,415 @@
+import IAnimationSet = require("awayjs-core/lib/animators/IAnimationSet");
+import AnimationNodeBase = require("awayjs-core/lib/animators/nodes/AnimationNodeBase");
+import ISubMesh = require("awayjs-core/lib/core/base/ISubMesh");
+import SubGeometryBase = require("awayjs-core/lib/core/base/SubGeometryBase");
+import Mesh = require("awayjs-core/lib/entities/Mesh");
+
+import AnimationSetBase = require("awayjs-stagegl/lib/animators/AnimationSetBase");
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticleAnimationData = require("awayjs-renderergl/lib/animators/data/ParticleAnimationData");
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleData = require("awayjs-renderergl/lib/animators/data/ParticleData");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleTimeNode = require("awayjs-renderergl/lib/animators/nodes/ParticleTimeNode");
+import ParticleGeometry = require("awayjs-renderergl/lib/core/base/ParticleGeometry");
+
+/**
+ * The animation data set used by particle-based animators, containing particle animation data.
+ *
+ * @see away.animators.ParticleAnimator
+ */
+class ParticleAnimationSet extends AnimationSetBase implements IAnimationSet
+{
+ /** @private */
+ public _iAnimationRegisterCache:AnimationRegisterCache;
+
+ //all other nodes dependent on it
+ private _timeNode:ParticleTimeNode;
+
+ /**
+ * Property used by particle nodes that require compilation at the end of the shader
+ */
+ public static POST_PRIORITY:number /*int*/ = 9;
+
+ /**
+ * Property used by particle nodes that require color compilation
+ */
+ public static COLOR_PRIORITY:number /*int*/ = 18;
+
+ private _animationSubGeometries:Object = new Object();
+ private _particleNodes:Array = new Array();
+ private _localDynamicNodes:Array = new Array();
+ private _localStaticNodes:Array = new Array();
+ private _totalLenOfOneVertex:number /*int*/ = 0;
+
+ //set true if has an node which will change UV
+ public hasUVNode:boolean;
+ //set if the other nodes need to access the velocity
+ public needVelocity:boolean;
+ //set if has a billboard node.
+ public hasBillboard:boolean;
+ //set if has an node which will apply color multiple operation
+ public hasColorMulNode:boolean;
+ //set if has an node which will apply color add operation
+ public hasColorAddNode:boolean;
+
+ /**
+ * Initialiser function for static particle properties. Needs to reference a with the following format
+ *
+ *
+ * initParticleFunc(prop:ParticleProperties)
+ * {
+ * //code for settings local properties
+ * }
+ *
+ *
+ * Aside from setting any properties required in particle animation nodes using local static properties, the initParticleFunc function
+ * is required to time node requirements as they may be needed. These properties on the ParticleProperties object can include
+ * startTime
, duration
and delay
. The use of these properties is determined by the setting
+ * arguments passed in the constructor of the particle animation set. By default, only the startTime
property is required.
+ */
+ public initParticleFunc:Function;
+
+ /**
+ * Initialiser function scope for static particle properties
+ */
+ public initParticleScope:Object;
+
+ /**
+ * Creates a new ParticleAnimationSet
+ *
+ * @param [optional] usesDuration Defines whether the animation set uses the duration
data in its static properties to determine how long a particle is visible for. Defaults to false.
+ * @param [optional] usesLooping Defines whether the animation set uses a looping timeframe for each particle determined by the startTime
, duration
and delay
data in its static properties function. Defaults to false. Requires usesDuration
to be true.
+ * @param [optional] usesDelay Defines whether the animation set uses the delay
data in its static properties to determine how long a particle is hidden for. Defaults to false. Requires usesLooping
to be true.
+ */
+ constructor(usesDuration:boolean = false, usesLooping:boolean = false, usesDelay:boolean = false)
+ {
+ super();
+
+ //automatically add a particle time node to the set
+ this.addAnimation(this._timeNode = new ParticleTimeNode(usesDuration, usesLooping, usesDelay));
+ }
+
+ /**
+ * Returns a vector of the particle animation nodes contained within the set.
+ */
+ public get particleNodes():Array
+ {
+ return this._particleNodes;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public addAnimation(node:AnimationNodeBase)
+ {
+ var i:number /*int*/;
+ var n:ParticleNodeBase = node;
+ n._iProcessAnimationSetting(this);
+ if (n.mode == ParticlePropertiesMode.LOCAL_STATIC) {
+ n._iDataOffset = this._totalLenOfOneVertex;
+ this._totalLenOfOneVertex += n.dataLength;
+ this._localStaticNodes.push(n);
+ } else if (n.mode == ParticlePropertiesMode.LOCAL_DYNAMIC)
+ this._localDynamicNodes.push(n);
+
+ for (i = this._particleNodes.length - 1; i >= 0; i--) {
+ if (this._particleNodes[i].priority <= n.priority)
+ break;
+ }
+
+ this._particleNodes.splice(i + 1, 0, n);
+
+ super.addAnimation(node);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public activate(shaderObject:ShaderObjectBase, stage:Stage)
+ {
+// this._iAnimationRegisterCache = pass.animationRegisterCache;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public deactivate(shaderObject:ShaderObjectBase, stage:Stage)
+ {
+// var context:IContextStageGL = stage.context;
+// var offset:number /*int*/ = this._iAnimationRegisterCache.vertexAttributesOffset;
+// var used:number /*int*/ = this._iAnimationRegisterCache.numUsedStreams;
+// for (var i:number /*int*/ = offset; i < used; i++)
+// context.setVertexBufferAt(i, null);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALVertexCode(shaderObject:ShaderObjectBase):string
+ {
+ //grab animationRegisterCache from the materialpassbase or create a new one if the first time
+ this._iAnimationRegisterCache = shaderObject.animationRegisterCache;
+
+ if (this._iAnimationRegisterCache == null)
+ this._iAnimationRegisterCache = shaderObject.animationRegisterCache = new AnimationRegisterCache(shaderObject.profile);
+
+ //reset animationRegisterCache
+ this._iAnimationRegisterCache.vertexConstantOffset = shaderObject.numUsedVertexConstants;
+ this._iAnimationRegisterCache.vertexAttributesOffset = shaderObject.numUsedStreams;
+ this._iAnimationRegisterCache.varyingsOffset = shaderObject.numUsedVaryings;
+ this._iAnimationRegisterCache.fragmentConstantOffset = shaderObject.numUsedFragmentConstants;
+ this._iAnimationRegisterCache.hasUVNode = this.hasUVNode;
+ this._iAnimationRegisterCache.needVelocity = this.needVelocity;
+ this._iAnimationRegisterCache.hasBillboard = this.hasBillboard;
+ this._iAnimationRegisterCache.sourceRegisters = shaderObject.animatableAttributes;
+ this._iAnimationRegisterCache.targetRegisters = shaderObject.animationTargetRegisters;
+ this._iAnimationRegisterCache.needFragmentAnimation = shaderObject.usesFragmentAnimation;
+ this._iAnimationRegisterCache.needUVAnimation = !shaderObject.usesUVTransform;
+ this._iAnimationRegisterCache.hasColorAddNode = this.hasColorAddNode;
+ this._iAnimationRegisterCache.hasColorMulNode = this.hasColorMulNode;
+ this._iAnimationRegisterCache.reset();
+
+ var code:string = "";
+
+ code += this._iAnimationRegisterCache.getInitCode();
+
+ var node:ParticleNodeBase;
+ var i:number /*int*/;
+
+ for (i = 0; i < this._particleNodes.length; i++) {
+ node = this._particleNodes[i];
+ if (node.priority < ParticleAnimationSet.POST_PRIORITY)
+ code += node.getAGALVertexCode(shaderObject, this._iAnimationRegisterCache);
+ }
+
+ code += this._iAnimationRegisterCache.getCombinationCode();
+
+ for (i = 0; i < this._particleNodes.length; i++) {
+ node = this._particleNodes[i];
+ if (node.priority >= ParticleAnimationSet.POST_PRIORITY && node.priority < ParticleAnimationSet.COLOR_PRIORITY)
+ code += node.getAGALVertexCode(shaderObject, this._iAnimationRegisterCache);
+ }
+
+ code += this._iAnimationRegisterCache.initColorRegisters();
+
+ for (i = 0; i < this._particleNodes.length; i++) {
+ node = this._particleNodes[i];
+ if (node.priority >= ParticleAnimationSet.COLOR_PRIORITY)
+ code += node.getAGALVertexCode(shaderObject, this._iAnimationRegisterCache);
+ }
+ code += this._iAnimationRegisterCache.getColorPassCode();
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALUVCode(shaderObject:ShaderObjectBase):string
+ {
+ var code:string = "";
+ if (this.hasUVNode) {
+ this._iAnimationRegisterCache.setUVSourceAndTarget(shaderObject.uvSource, shaderObject.uvTarget);
+ code += "mov " + this._iAnimationRegisterCache.uvTarget + ".xy," + this._iAnimationRegisterCache.uvAttribute.toString() + "\n";
+ var node:ParticleNodeBase;
+ for (var i:number /*uint*/ = 0; i < this._particleNodes.length; i++)
+ node = this._particleNodes[i];
+ code += node.getAGALUVCode(shaderObject, this._iAnimationRegisterCache);
+ code += "mov " + this._iAnimationRegisterCache.uvVar.toString() + "," + this._iAnimationRegisterCache.uvTarget + ".xy\n";
+ } else
+ code += "mov " + shaderObject.uvTarget + "," + shaderObject.uvSource + "\n";
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALFragmentCode(shaderObject:ShaderObjectBase, shadedTarget:string):string
+ {
+ return this._iAnimationRegisterCache.getColorCombinationCode(shadedTarget);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public doneAGALCode(shaderObject:ShaderObjectBase)
+ {
+ this._iAnimationRegisterCache.setDataLength();
+
+ //set vertexZeroConst,vertexOneConst,vertexTwoConst
+ this._iAnimationRegisterCache.setVertexConst(this._iAnimationRegisterCache.vertexZeroConst.index, 0, 1, 2, 0);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public get usesCPU():boolean
+ {
+ return false;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public cancelGPUCompatibility()
+ {
+
+ }
+
+ public dispose()
+ {
+ for (var key in this._animationSubGeometries)
+ ( this._animationSubGeometries[key]).dispose();
+
+ super.dispose();
+ }
+
+ public getAnimationSubGeometry(subMesh:ISubMesh)
+ {
+ var mesh:Mesh = subMesh.parentMesh;
+ var animationSubGeometry:AnimationSubGeometry = (mesh.shareAnimationGeometry)? this._animationSubGeometries[subMesh.subGeometry.id] : this._animationSubGeometries[subMesh.id];
+
+ if (animationSubGeometry)
+ return animationSubGeometry;
+
+ this._iGenerateAnimationSubGeometries(mesh);
+
+ return (mesh.shareAnimationGeometry)? this._animationSubGeometries[subMesh.subGeometry.id] : this._animationSubGeometries[subMesh.id];
+ }
+
+
+ /** @private */
+ public _iGenerateAnimationSubGeometries(mesh:Mesh)
+ {
+ if (this.initParticleFunc == null)
+ throw(new Error("no initParticleFunc set"));
+
+ var geometry:ParticleGeometry = mesh.geometry;
+
+ if (!geometry)
+ throw(new Error("Particle animation can only be performed on a ParticleGeometry object"));
+
+ var i:number /*int*/, j:number /*int*/, k:number /*int*/;
+ var animationSubGeometry:AnimationSubGeometry;
+ var newAnimationSubGeometry:boolean = false;
+ var subGeometry:SubGeometryBase;
+ var subMesh:ISubMesh;
+ var localNode:ParticleNodeBase;
+
+ for (i = 0; i < mesh.subMeshes.length; i++) {
+ subMesh = mesh.subMeshes[i];
+ subGeometry = subMesh.subGeometry;
+ if (mesh.shareAnimationGeometry) {
+ animationSubGeometry = this._animationSubGeometries[subGeometry.id];
+
+ if (animationSubGeometry)
+ continue;
+ }
+
+ animationSubGeometry = new AnimationSubGeometry();
+
+ if (mesh.shareAnimationGeometry)
+ this._animationSubGeometries[subGeometry.id] = animationSubGeometry;
+ else
+ this._animationSubGeometries[subMesh.id] = animationSubGeometry;
+
+ newAnimationSubGeometry = true;
+
+ //create the vertexData vector that will be used for local node data
+ animationSubGeometry.createVertexData(subGeometry.numVertices, this._totalLenOfOneVertex);
+ }
+
+ if (!newAnimationSubGeometry)
+ return;
+
+ var particles:Array = geometry.particles;
+ var particlesLength:number /*uint*/ = particles.length;
+ var numParticles:number /*uint*/ = geometry.numParticles;
+ var particleProperties:ParticleProperties = new ParticleProperties();
+ var particle:ParticleData;
+
+ var oneDataLen:number /*int*/;
+ var oneDataOffset:number /*int*/;
+ var counterForVertex:number /*int*/;
+ var counterForOneData:number /*int*/;
+ var oneData:Array;
+ var numVertices:number /*uint*/;
+ var vertexData:Array;
+ var vertexLength:number /*uint*/;
+ var startingOffset:number /*uint*/;
+ var vertexOffset:number /*uint*/;
+
+ //default values for particle param
+ particleProperties.total = numParticles;
+ particleProperties.startTime = 0;
+ particleProperties.duration = 1000;
+ particleProperties.delay = 0.1;
+
+ i = 0;
+ j = 0;
+ while (i < numParticles) {
+ particleProperties.index = i;
+
+ //call the init on the particle parameters
+ this.initParticleFunc.call(this.initParticleScope, particleProperties);
+
+ //create the next set of node properties for the particle
+ for (k = 0; k < this._localStaticNodes.length; k++)
+ this._localStaticNodes[k]._iGeneratePropertyOfOneParticle(particleProperties);
+
+ //loop through all particle data for the curent particle
+ while (j < particlesLength && (particle = particles[j]).particleIndex == i) {
+ //find the target animationSubGeometry
+ for (k = 0; k < mesh.subMeshes.length; k++) {
+ subMesh = mesh.subMeshes[k];
+ if (subMesh.subGeometry == particle.subGeometry) {
+ animationSubGeometry = (mesh.shareAnimationGeometry)? this._animationSubGeometries[subMesh.subGeometry.id] : this._animationSubGeometries[subMesh.id];
+ break;
+ }
+ }
+ numVertices = particle.numVertices;
+ vertexData = animationSubGeometry.vertexData;
+ vertexLength = numVertices*this._totalLenOfOneVertex;
+ startingOffset = animationSubGeometry.numProcessedVertices*this._totalLenOfOneVertex;
+
+ //loop through each static local node in the animation set
+ for (k = 0; k < this._localStaticNodes.length; k++) {
+ localNode = this._localStaticNodes[k];
+ oneData = localNode.oneData;
+ oneDataLen = localNode.dataLength;
+ oneDataOffset = startingOffset + localNode._iDataOffset;
+
+ //loop through each vertex set in the vertex data
+ for (counterForVertex = 0; counterForVertex < vertexLength; counterForVertex += this._totalLenOfOneVertex) {
+ vertexOffset = oneDataOffset + counterForVertex;
+
+ //add the data for the local node to the vertex data
+ for (counterForOneData = 0; counterForOneData < oneDataLen; counterForOneData++)
+ vertexData[vertexOffset + counterForOneData] = oneData[counterForOneData];
+ }
+
+ }
+
+ //store particle properties if they need to be retreived for dynamic local nodes
+ if (this._localDynamicNodes.length)
+ animationSubGeometry.animationParticles.push(new ParticleAnimationData(i, particleProperties.startTime, particleProperties.duration, particleProperties.delay, particle));
+
+ animationSubGeometry.numProcessedVertices += numVertices;
+
+ //next index
+ j++;
+ }
+
+ //next particle
+ i++;
+ }
+ }
+}
+
+export = ParticleAnimationSet;
\ No newline at end of file
diff --git a/lib/animators/ParticleAnimator.js b/lib/animators/ParticleAnimator.js
new file mode 100755
index 000000000..dc03af739
--- /dev/null
+++ b/lib/animators/ParticleAnimator.js
@@ -0,0 +1,128 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+var ContextGLProgramType = require("awayjs-stagegl/lib/core/stagegl/ContextGLProgramType");
+var AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+/**
+ * Provides an interface for assigning paricle-based animation data sets to mesh-based entity objects
+ * and controlling the various available states of animation through an interative playhead that can be
+ * automatically updated or manually triggered.
+ *
+ * Requires that the containing geometry of the parent mesh is particle geometry
+ *
+ * @see away.base.ParticleGeometry
+ */
+var ParticleAnimator = (function (_super) {
+ __extends(ParticleAnimator, _super);
+ /**
+ * Creates a new ParticleAnimator
object.
+ *
+ * @param particleAnimationSet The animation data set containing the particle animations used by the animator.
+ */
+ function ParticleAnimator(particleAnimationSet) {
+ _super.call(this, particleAnimationSet);
+ this._animationParticleStates = new Array();
+ this._animatorParticleStates = new Array();
+ this._timeParticleStates = new Array();
+ this._totalLenOfOneVertex = 0;
+ this._animatorSubGeometries = new Object();
+ this._particleAnimationSet = particleAnimationSet;
+ var state;
+ var node;
+ for (var i = 0; i < this._particleAnimationSet.particleNodes.length; i++) {
+ node = this._particleAnimationSet.particleNodes[i];
+ state = this.getAnimationState(node);
+ if (node.mode == ParticlePropertiesMode.LOCAL_DYNAMIC) {
+ this._animatorParticleStates.push(state);
+ node._iDataOffset = this._totalLenOfOneVertex;
+ this._totalLenOfOneVertex += node.dataLength;
+ }
+ else {
+ this._animationParticleStates.push(state);
+ }
+ if (state.needUpdateTime)
+ this._timeParticleStates.push(state);
+ }
+ }
+ /**
+ * @inheritDoc
+ */
+ ParticleAnimator.prototype.clone = function () {
+ return new ParticleAnimator(this._particleAnimationSet);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleAnimator.prototype.setRenderState = function (shaderObject, renderable, stage, camera, vertexConstantOffset /*int*/, vertexStreamOffset /*int*/) {
+ var animationRegisterCache = this._particleAnimationSet._iAnimationRegisterCache;
+ var subMesh = renderable.subMesh;
+ var state;
+ var i;
+ if (!subMesh)
+ throw (new Error("Must be subMesh"));
+ //process animation sub geometries
+ var animationSubGeometry = this._particleAnimationSet.getAnimationSubGeometry(subMesh);
+ for (i = 0; i < this._animationParticleStates.length; i++)
+ this._animationParticleStates[i].setRenderState(stage, renderable, animationSubGeometry, animationRegisterCache, camera);
+ //process animator subgeometries
+ var animatorSubGeometry = this.getAnimatorSubGeometry(subMesh);
+ for (i = 0; i < this._animatorParticleStates.length; i++)
+ this._animatorParticleStates[i].setRenderState(stage, renderable, animatorSubGeometry, animationRegisterCache, camera);
+ stage.context.setProgramConstantsFromArray(ContextGLProgramType.VERTEX, animationRegisterCache.vertexConstantOffset, animationRegisterCache.vertexConstantData, animationRegisterCache.numVertexConstant);
+ if (animationRegisterCache.numFragmentConstant > 0)
+ stage.context.setProgramConstantsFromArray(ContextGLProgramType.FRAGMENT, animationRegisterCache.fragmentConstantOffset, animationRegisterCache.fragmentConstantData, animationRegisterCache.numFragmentConstant);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleAnimator.prototype.testGPUCompatibility = function (shaderObject) {
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleAnimator.prototype.start = function () {
+ _super.prototype.start.call(this);
+ for (var i = 0; i < this._timeParticleStates.length; i++)
+ this._timeParticleStates[i].offset(this._pAbsoluteTime);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleAnimator.prototype._pUpdateDeltaTime = function (dt) {
+ this._pAbsoluteTime += dt;
+ for (var i = 0; i < this._timeParticleStates.length; i++)
+ this._timeParticleStates[i].update(this._pAbsoluteTime);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleAnimator.prototype.resetTime = function (offset) {
+ if (offset === void 0) { offset = 0; }
+ for (var i = 0; i < this._timeParticleStates.length; i++)
+ this._timeParticleStates[i].offset(this._pAbsoluteTime + offset);
+ this.update(this.time);
+ };
+ ParticleAnimator.prototype.dispose = function () {
+ for (var key in this._animatorSubGeometries)
+ this._animatorSubGeometries[key].dispose();
+ };
+ ParticleAnimator.prototype.getAnimatorSubGeometry = function (subMesh) {
+ if (!this._animatorParticleStates.length)
+ return;
+ var subGeometry = subMesh.subGeometry;
+ var animatorSubGeometry = this._animatorSubGeometries[subGeometry.id] = new AnimationSubGeometry();
+ //create the vertexData vector that will be used for local state data
+ animatorSubGeometry.createVertexData(subGeometry.numVertices, this._totalLenOfOneVertex);
+ //pass the particles data to the animator subGeometry
+ animatorSubGeometry.animationParticles = this._particleAnimationSet.getAnimationSubGeometry(subMesh).animationParticles;
+ };
+ return ParticleAnimator;
+})(AnimatorBase);
+module.exports = ParticleAnimator;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/particleanimator.ts"],"names":["ParticleAnimator","ParticleAnimator.constructor","ParticleAnimator.clone","ParticleAnimator.setRenderState","ParticleAnimator.testGPUCompatibility","ParticleAnimator.start","ParticleAnimator._pUpdateDeltaTime","ParticleAnimator.resetTime","ParticleAnimator.dispose","ParticleAnimator.getAnimatorSubGeometry"],"mappings":"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","file":"animators/ParticleAnimator.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import ISubMesh\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/base/ISubMesh\");\nimport SubGeometryBase\t\t\t\t\t= require(\"awayjs-core/lib/core/base/SubGeometryBase\");\nimport Camera\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Camera\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport RenderableBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/RenderableBase\");\nimport TriangleSubMeshRenderable\t\t= require(\"awayjs-stagegl/lib/core/pool/TriangleSubMeshRenderable\");\nimport ContextGLProgramType\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/ContextGLProgramType\");\nimport IContextStageGL\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/IContextStageGL\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\n\nimport ParticleAnimationSet\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimationSet\");\nimport AnimationSubGeometry\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/AnimationSubGeometry\");\nimport ParticleAnimationData\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleAnimationData\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleNodeBase\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleNodeBase\");\nimport ParticleStateBase\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleStateBase\");\n\n/**\n * Provides an interface for assigning paricle-based animation data sets to mesh-based entity objects\n * and controlling the various available states of animation through an interative playhead that can be\n * automatically updated or manually triggered.\n *\n * Requires that the containing geometry of the parent mesh is particle geometry\n *\n * @see away.base.ParticleGeometry\n */\nclass ParticleAnimator extends AnimatorBase\n{\n\n\tprivate _particleAnimationSet:ParticleAnimationSet;\n\tprivate _animationParticleStates:Array<ParticleStateBase> = new Array<ParticleStateBase>();\n\tprivate _animatorParticleStates:Array<ParticleStateBase> = new Array<ParticleStateBase>();\n\tprivate _timeParticleStates:Array<ParticleStateBase> = new Array<ParticleStateBase>();\n\tprivate _totalLenOfOneVertex:number /*uint*/ = 0;\n\tprivate _animatorSubGeometries:Object = new Object();\n\n\t/**\n\t * Creates a new <code>ParticleAnimator</code> object.\n\t *\n\t * @param particleAnimationSet The animation data set containing the particle animations used by the animator.\n\t */\n\tconstructor(particleAnimationSet:ParticleAnimationSet)\n\t{\n\t\tsuper(particleAnimationSet);\n\t\tthis._particleAnimationSet = particleAnimationSet;\n\n\t\tvar state:ParticleStateBase;\n\t\tvar node:ParticleNodeBase;\n\n\t\tfor (var i:number = 0; i < this._particleAnimationSet.particleNodes.length; i++) {\n\t\t\tnode = this._particleAnimationSet.particleNodes[i];\n\t\t\tstate = <ParticleStateBase> this.getAnimationState(node);\n\t\t\tif (node.mode == ParticlePropertiesMode.LOCAL_DYNAMIC) {\n\t\t\t\tthis._animatorParticleStates.push(state);\n\t\t\t\tnode._iDataOffset = this._totalLenOfOneVertex;\n\t\t\t\tthis._totalLenOfOneVertex += node.dataLength;\n\t\t\t} else {\n\t\t\t\tthis._animationParticleStates.push(state);\n\t\t\t}\n\t\t\tif (state.needUpdateTime)\n\t\t\t\tthis._timeParticleStates.push(state);\n\t\t}\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic clone():AnimatorBase\n\t{\n\t\treturn new ParticleAnimator(this._particleAnimationSet);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic setRenderState(shaderObject:ShaderObjectBase, renderable:RenderableBase, stage:Stage, camera:Camera, vertexConstantOffset:number /*int*/, vertexStreamOffset:number /*int*/)\n\t{\n\t\tvar animationRegisterCache:AnimationRegisterCache = this._particleAnimationSet._iAnimationRegisterCache;\n\n\t\tvar subMesh:ISubMesh = (<TriangleSubMeshRenderable> renderable).subMesh;\n\t\tvar state:ParticleStateBase;\n\t\tvar i:number;\n\n\t\tif (!subMesh)\n\t\t\tthrow(new Error(\"Must be subMesh\"));\n\n\t\t//process animation sub geometries\n\t\tvar animationSubGeometry:AnimationSubGeometry = this._particleAnimationSet.getAnimationSubGeometry(subMesh);\n\n\t\tfor (i = 0; i < this._animationParticleStates.length; i++)\n\t\t\tthis._animationParticleStates[i].setRenderState(stage, renderable, animationSubGeometry, animationRegisterCache, camera);\n\n\t\t//process animator subgeometries\n\t\tvar animatorSubGeometry:AnimationSubGeometry = this.getAnimatorSubGeometry(subMesh);\n\n\t\tfor (i = 0; i < this._animatorParticleStates.length; i++)\n\t\t\tthis._animatorParticleStates[i].setRenderState(stage, renderable, animatorSubGeometry, animationRegisterCache, camera);\n\n\t\t(<IContextStageGL> stage.context).setProgramConstantsFromArray(ContextGLProgramType.VERTEX, animationRegisterCache.vertexConstantOffset, animationRegisterCache.vertexConstantData, animationRegisterCache.numVertexConstant);\n\n\t\tif (animationRegisterCache.numFragmentConstant > 0)\n\t\t\t(<IContextStageGL> stage.context).setProgramConstantsFromArray(ContextGLProgramType.FRAGMENT, animationRegisterCache.fragmentConstantOffset, animationRegisterCache.fragmentConstantData, animationRegisterCache.numFragmentConstant);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic testGPUCompatibility(shaderObject:ShaderObjectBase)\n\t{\n\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic start()\n\t{\n\t\tsuper.start();\n\n\t\tfor (var i:number = 0; i < this._timeParticleStates.length; i++)\n\t\t\tthis._timeParticleStates[i].offset(this._pAbsoluteTime);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _pUpdateDeltaTime(dt:number)\n\t{\n\t\tthis._pAbsoluteTime += dt;\n\n\t\tfor (var i:number = 0; i < this._timeParticleStates.length; i++)\n\t\t\tthis._timeParticleStates[i].update(this._pAbsoluteTime);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic resetTime(offset:number /*int*/ = 0)\n\t{\n\t\tfor (var i:number = 0; i < this._timeParticleStates.length; i++)\n\t\t\tthis._timeParticleStates[i].offset(this._pAbsoluteTime + offset);\n\t\tthis.update(this.time);\n\t}\n\n\tpublic dispose()\n\t{\n\t\tfor (var key in this._animatorSubGeometries)\n\t\t\t(<AnimationSubGeometry> this._animatorSubGeometries[key]).dispose();\n\t}\n\n\tprivate getAnimatorSubGeometry(subMesh:ISubMesh):AnimationSubGeometry\n\t{\n\t\tif (!this._animatorParticleStates.length)\n\t\t\treturn;\n\n\t\tvar subGeometry:SubGeometryBase = subMesh.subGeometry;\n\t\tvar animatorSubGeometry:AnimationSubGeometry = this._animatorSubGeometries[subGeometry.id] = new AnimationSubGeometry();\n\n\t\t//create the vertexData vector that will be used for local state data\n\t\tanimatorSubGeometry.createVertexData(subGeometry.numVertices, this._totalLenOfOneVertex);\n\n\t\t//pass the particles data to the animator subGeometry\n\t\tanimatorSubGeometry.animationParticles = this._particleAnimationSet.getAnimationSubGeometry(subMesh).animationParticles;\n\t}\n}\n\nexport = ParticleAnimator;"]}
\ No newline at end of file
diff --git a/lib/animators/ParticleAnimator.ts b/lib/animators/ParticleAnimator.ts
new file mode 100644
index 000000000..25e389fbc
--- /dev/null
+++ b/lib/animators/ParticleAnimator.ts
@@ -0,0 +1,170 @@
+import ISubMesh = require("awayjs-core/lib/core/base/ISubMesh");
+import SubGeometryBase = require("awayjs-core/lib/core/base/SubGeometryBase");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import TriangleSubMeshRenderable = require("awayjs-stagegl/lib/core/pool/TriangleSubMeshRenderable");
+import ContextGLProgramType = require("awayjs-stagegl/lib/core/stagegl/ContextGLProgramType");
+import IContextStageGL = require("awayjs-stagegl/lib/core/stagegl/IContextStageGL");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+
+import ParticleAnimationSet = require("awayjs-renderergl/lib/animators/ParticleAnimationSet");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticleAnimationData = require("awayjs-renderergl/lib/animators/data/ParticleAnimationData");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+
+/**
+ * Provides an interface for assigning paricle-based animation data sets to mesh-based entity objects
+ * and controlling the various available states of animation through an interative playhead that can be
+ * automatically updated or manually triggered.
+ *
+ * Requires that the containing geometry of the parent mesh is particle geometry
+ *
+ * @see away.base.ParticleGeometry
+ */
+class ParticleAnimator extends AnimatorBase
+{
+
+ private _particleAnimationSet:ParticleAnimationSet;
+ private _animationParticleStates:Array = new Array();
+ private _animatorParticleStates:Array = new Array();
+ private _timeParticleStates:Array = new Array();
+ private _totalLenOfOneVertex:number /*uint*/ = 0;
+ private _animatorSubGeometries:Object = new Object();
+
+ /**
+ * Creates a new ParticleAnimator
object.
+ *
+ * @param particleAnimationSet The animation data set containing the particle animations used by the animator.
+ */
+ constructor(particleAnimationSet:ParticleAnimationSet)
+ {
+ super(particleAnimationSet);
+ this._particleAnimationSet = particleAnimationSet;
+
+ var state:ParticleStateBase;
+ var node:ParticleNodeBase;
+
+ for (var i:number = 0; i < this._particleAnimationSet.particleNodes.length; i++) {
+ node = this._particleAnimationSet.particleNodes[i];
+ state = this.getAnimationState(node);
+ if (node.mode == ParticlePropertiesMode.LOCAL_DYNAMIC) {
+ this._animatorParticleStates.push(state);
+ node._iDataOffset = this._totalLenOfOneVertex;
+ this._totalLenOfOneVertex += node.dataLength;
+ } else {
+ this._animationParticleStates.push(state);
+ }
+ if (state.needUpdateTime)
+ this._timeParticleStates.push(state);
+ }
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public clone():AnimatorBase
+ {
+ return new ParticleAnimator(this._particleAnimationSet);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public setRenderState(shaderObject:ShaderObjectBase, renderable:RenderableBase, stage:Stage, camera:Camera, vertexConstantOffset:number /*int*/, vertexStreamOffset:number /*int*/)
+ {
+ var animationRegisterCache:AnimationRegisterCache = this._particleAnimationSet._iAnimationRegisterCache;
+
+ var subMesh:ISubMesh = ( renderable).subMesh;
+ var state:ParticleStateBase;
+ var i:number;
+
+ if (!subMesh)
+ throw(new Error("Must be subMesh"));
+
+ //process animation sub geometries
+ var animationSubGeometry:AnimationSubGeometry = this._particleAnimationSet.getAnimationSubGeometry(subMesh);
+
+ for (i = 0; i < this._animationParticleStates.length; i++)
+ this._animationParticleStates[i].setRenderState(stage, renderable, animationSubGeometry, animationRegisterCache, camera);
+
+ //process animator subgeometries
+ var animatorSubGeometry:AnimationSubGeometry = this.getAnimatorSubGeometry(subMesh);
+
+ for (i = 0; i < this._animatorParticleStates.length; i++)
+ this._animatorParticleStates[i].setRenderState(stage, renderable, animatorSubGeometry, animationRegisterCache, camera);
+
+ ( stage.context).setProgramConstantsFromArray(ContextGLProgramType.VERTEX, animationRegisterCache.vertexConstantOffset, animationRegisterCache.vertexConstantData, animationRegisterCache.numVertexConstant);
+
+ if (animationRegisterCache.numFragmentConstant > 0)
+ ( stage.context).setProgramConstantsFromArray(ContextGLProgramType.FRAGMENT, animationRegisterCache.fragmentConstantOffset, animationRegisterCache.fragmentConstantData, animationRegisterCache.numFragmentConstant);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public testGPUCompatibility(shaderObject:ShaderObjectBase)
+ {
+
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public start()
+ {
+ super.start();
+
+ for (var i:number = 0; i < this._timeParticleStates.length; i++)
+ this._timeParticleStates[i].offset(this._pAbsoluteTime);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pUpdateDeltaTime(dt:number)
+ {
+ this._pAbsoluteTime += dt;
+
+ for (var i:number = 0; i < this._timeParticleStates.length; i++)
+ this._timeParticleStates[i].update(this._pAbsoluteTime);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public resetTime(offset:number /*int*/ = 0)
+ {
+ for (var i:number = 0; i < this._timeParticleStates.length; i++)
+ this._timeParticleStates[i].offset(this._pAbsoluteTime + offset);
+ this.update(this.time);
+ }
+
+ public dispose()
+ {
+ for (var key in this._animatorSubGeometries)
+ ( this._animatorSubGeometries[key]).dispose();
+ }
+
+ private getAnimatorSubGeometry(subMesh:ISubMesh):AnimationSubGeometry
+ {
+ if (!this._animatorParticleStates.length)
+ return;
+
+ var subGeometry:SubGeometryBase = subMesh.subGeometry;
+ var animatorSubGeometry:AnimationSubGeometry = this._animatorSubGeometries[subGeometry.id] = new AnimationSubGeometry();
+
+ //create the vertexData vector that will be used for local state data
+ animatorSubGeometry.createVertexData(subGeometry.numVertices, this._totalLenOfOneVertex);
+
+ //pass the particles data to the animator subGeometry
+ animatorSubGeometry.animationParticles = this._particleAnimationSet.getAnimationSubGeometry(subMesh).animationParticles;
+ }
+}
+
+export = ParticleAnimator;
\ No newline at end of file
diff --git a/lib/animators/SkeletonAnimationSet.js b/lib/animators/SkeletonAnimationSet.js
new file mode 100755
index 000000000..e780a1a9f
--- /dev/null
+++ b/lib/animators/SkeletonAnimationSet.js
@@ -0,0 +1,103 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var AnimationSetBase = require("awayjs-stagegl/lib/animators/AnimationSetBase");
+/**
+ * The animation data set used by skeleton-based animators, containing skeleton animation data.
+ *
+ * @see away.animators.SkeletonAnimator
+ */
+var SkeletonAnimationSet = (function (_super) {
+ __extends(SkeletonAnimationSet, _super);
+ /**
+ * Creates a new SkeletonAnimationSet
object.
+ *
+ * @param jointsPerVertex Sets the amount of skeleton joints that can be linked to a single vertex via skinned weight values. For GPU-base animation, the maximum allowed value is 4. Defaults to 4.
+ */
+ function SkeletonAnimationSet(jointsPerVertex) {
+ if (jointsPerVertex === void 0) { jointsPerVertex = 4; }
+ _super.call(this);
+ this._jointsPerVertex = jointsPerVertex;
+ }
+ Object.defineProperty(SkeletonAnimationSet.prototype, "jointsPerVertex", {
+ /**
+ * Returns the amount of skeleton joints that can be linked to a single vertex via skinned weight values. For GPU-base animation, the
+ * maximum allowed value is 4.
+ */
+ get: function () {
+ return this._jointsPerVertex;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ SkeletonAnimationSet.prototype.getAGALVertexCode = function (shaderObject) {
+ var len = shaderObject.animatableAttributes.length;
+ var indexOffset0 = shaderObject.numUsedVertexConstants;
+ var indexOffset1 = indexOffset0 + 1;
+ var indexOffset2 = indexOffset0 + 2;
+ var indexStream = "va" + shaderObject.numUsedStreams;
+ var weightStream = "va" + (shaderObject.numUsedStreams + 1);
+ var indices = [indexStream + ".x", indexStream + ".y", indexStream + ".z", indexStream + ".w"];
+ var weights = [weightStream + ".x", weightStream + ".y", weightStream + ".z", weightStream + ".w"];
+ var temp1 = this._pFindTempReg(shaderObject.animationTargetRegisters);
+ var temp2 = this._pFindTempReg(shaderObject.animationTargetRegisters, temp1);
+ var dot = "dp4";
+ var code = "";
+ for (var i = 0; i < len; ++i) {
+ var src = shaderObject.animatableAttributes[i];
+ for (var j = 0; j < this._jointsPerVertex; ++j) {
+ code += dot + " " + temp1 + ".x, " + src + ", vc[" + indices[j] + "+" + indexOffset0 + "]\n" + dot + " " + temp1 + ".y, " + src + ", vc[" + indices[j] + "+" + indexOffset1 + "]\n" + dot + " " + temp1 + ".z, " + src + ", vc[" + indices[j] + "+" + indexOffset2 + "]\n" + "mov " + temp1 + ".w, " + src + ".w\n" + "mul " + temp1 + ", " + temp1 + ", " + weights[j] + "\n"; // apply weight
+ // add or mov to target. Need to write to a temp reg first, because an output can be a target
+ if (j == 0)
+ code += "mov " + temp2 + ", " + temp1 + "\n";
+ else
+ code += "add " + temp2 + ", " + temp2 + ", " + temp1 + "\n";
+ }
+ // switch to dp3 once positions have been transformed, from now on, it should only be vectors instead of points
+ dot = "dp3";
+ code += "mov " + shaderObject.animationTargetRegisters[i] + ", " + temp2 + "\n";
+ }
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonAnimationSet.prototype.activate = function (shaderObject, stage) {
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonAnimationSet.prototype.deactivate = function (shaderObject, stage) {
+ // var streamOffset:number /*uint*/ = pass.numUsedStreams;
+ // var context:IContextStageGL = stage.context;
+ // context.setVertexBufferAt(streamOffset, null);
+ // context.setVertexBufferAt(streamOffset + 1, null);
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonAnimationSet.prototype.getAGALFragmentCode = function (shaderObject, shadedTarget) {
+ return "";
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonAnimationSet.prototype.getAGALUVCode = function (shaderObject) {
+ return "mov " + shaderObject.uvTarget + "," + shaderObject.uvSource + "\n";
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonAnimationSet.prototype.doneAGALCode = function (shaderObject) {
+ };
+ return SkeletonAnimationSet;
+})(AnimationSetBase);
+module.exports = SkeletonAnimationSet;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/skeletonanimationset.ts"],"names":["SkeletonAnimationSet","SkeletonAnimationSet.constructor","SkeletonAnimationSet.jointsPerVertex","SkeletonAnimationSet.getAGALVertexCode","SkeletonAnimationSet.activate","SkeletonAnimationSet.deactivate","SkeletonAnimationSet.getAGALFragmentCode","SkeletonAnimationSet.getAGALUVCode","SkeletonAnimationSet.doneAGALCode"],"mappings":"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","file":"animators/SkeletonAnimationSet.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import IAnimationSet\t\t\t\t\t= require(\"awayjs-core/lib/animators/IAnimationSet\");\n\nimport AnimationSetBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimationSetBase\");\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\n\n/**\n * The animation data set used by skeleton-based animators, containing skeleton animation data.\n *\n * @see away.animators.SkeletonAnimator\n */\nclass SkeletonAnimationSet extends AnimationSetBase implements IAnimationSet\n{\n\tprivate _jointsPerVertex:number /*uint*/;\n\n\t/**\n\t * Returns the amount of skeleton joints that can be linked to a single vertex via skinned weight values. For GPU-base animation, the\n\t * maximum allowed value is 4.\n\t */\n\tpublic get jointsPerVertex():number /*uint*/\n\t{\n\t\treturn this._jointsPerVertex;\n\t}\n\n\t/**\n\t * Creates a new <code>SkeletonAnimationSet</code> object.\n\t *\n\t * @param jointsPerVertex Sets the amount of skeleton joints that can be linked to a single vertex via skinned weight values. For GPU-base animation, the maximum allowed value is 4. Defaults to 4.\n\t */\n\tconstructor(jointsPerVertex:number /*uint*/ = 4)\n\t{\n\t\tsuper();\n\n\t\tthis._jointsPerVertex = jointsPerVertex;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALVertexCode(shaderObject:ShaderObjectBase):string\n\t{\n\t\tvar len:number /*uint*/ = shaderObject.animatableAttributes.length;\n\n\t\tvar indexOffset0:number /*uint*/ = shaderObject.numUsedVertexConstants;\n\t\tvar indexOffset1:number /*uint*/ = indexOffset0 + 1;\n\t\tvar indexOffset2:number /*uint*/ = indexOffset0 + 2;\n\t\tvar indexStream:string = \"va\" + shaderObject.numUsedStreams;\n\t\tvar weightStream:string = \"va\" + (shaderObject.numUsedStreams + 1);\n\t\tvar indices:Array<string> = [ indexStream + \".x\", indexStream + \".y\", indexStream + \".z\", indexStream + \".w\" ];\n\t\tvar weights:Array<string> = [ weightStream + \".x\", weightStream + \".y\", weightStream + \".z\", weightStream + \".w\" ];\n\t\tvar temp1:string = this._pFindTempReg(shaderObject.animationTargetRegisters);\n\t\tvar temp2:string = this._pFindTempReg(shaderObject.animationTargetRegisters, temp1);\n\t\tvar dot:string = \"dp4\";\n\t\tvar code:string = \"\";\n\n\t\tfor (var i:number /*uint*/ = 0; i < len; ++i) {\n\n\t\t\tvar src:string = shaderObject.animatableAttributes[i];\n\n\t\t\tfor (var j:number /*uint*/ = 0; j < this._jointsPerVertex; ++j) {\n\t\t\t\tcode += dot + \" \" + temp1 + \".x, \" + src + \", vc[\" + indices[j] + \"+\" + indexOffset0 + \"]\\n\" +\n\t\t\t\t\tdot + \" \" + temp1 + \".y, \" + src + \", vc[\" + indices[j] + \"+\" + indexOffset1 + \"]\\n\" +\n\t\t\t\t\tdot + \" \" + temp1 + \".z, \" + src + \", vc[\" + indices[j] + \"+\" + indexOffset2 + \"]\\n\" +\n\t\t\t\t\t\"mov \" + temp1 + \".w, \" + src + \".w\\n\" +\n\t\t\t\t\t\"mul \" + temp1 + \", \" + temp1 + \", \" + weights[j] + \"\\n\"; // apply weight\n\n\t\t\t\t// add or mov to target. Need to write to a temp reg first, because an output can be a target\n\t\t\t\tif (j == 0)\n\t\t\t\t\tcode += \"mov \" + temp2 + \", \" + temp1 + \"\\n\"; else\n\t\t\t\t\tcode += \"add \" + temp2 + \", \" + temp2 + \", \" + temp1 + \"\\n\";\n\t\t\t}\n\t\t\t// switch to dp3 once positions have been transformed, from now on, it should only be vectors instead of points\n\t\t\tdot = \"dp3\";\n\t\t\tcode += \"mov \" + shaderObject.animationTargetRegisters[i] + \", \" + temp2 + \"\\n\";\n\t\t}\n\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic activate(shaderObject:ShaderObjectBase, stage:Stage)\n\t{\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic deactivate(shaderObject:ShaderObjectBase, stage:Stage)\n\t{\n//\t\t\tvar streamOffset:number /*uint*/ = pass.numUsedStreams;\n//\t\t\tvar context:IContextStageGL = <IContextStageGL> stage.context;\n//\t\t\tcontext.setVertexBufferAt(streamOffset, null);\n//\t\t\tcontext.setVertexBufferAt(streamOffset + 1, null);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALFragmentCode(shaderObject:ShaderObjectBase, shadedTarget:string):string\n\t{\n\t\treturn \"\";\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALUVCode(shaderObject:ShaderObjectBase):string\n\t{\n\t\treturn \"mov \" + shaderObject.uvTarget + \",\" + shaderObject.uvSource + \"\\n\";\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic doneAGALCode(shaderObject:ShaderObjectBase)\n\t{\n\n\t}\n}\n\nexport = SkeletonAnimationSet;"]}
\ No newline at end of file
diff --git a/lib/animators/SkeletonAnimationSet.ts b/lib/animators/SkeletonAnimationSet.ts
new file mode 100644
index 000000000..c14fd07cd
--- /dev/null
+++ b/lib/animators/SkeletonAnimationSet.ts
@@ -0,0 +1,123 @@
+import IAnimationSet = require("awayjs-core/lib/animators/IAnimationSet");
+
+import AnimationSetBase = require("awayjs-stagegl/lib/animators/AnimationSetBase");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+
+/**
+ * The animation data set used by skeleton-based animators, containing skeleton animation data.
+ *
+ * @see away.animators.SkeletonAnimator
+ */
+class SkeletonAnimationSet extends AnimationSetBase implements IAnimationSet
+{
+ private _jointsPerVertex:number /*uint*/;
+
+ /**
+ * Returns the amount of skeleton joints that can be linked to a single vertex via skinned weight values. For GPU-base animation, the
+ * maximum allowed value is 4.
+ */
+ public get jointsPerVertex():number /*uint*/
+ {
+ return this._jointsPerVertex;
+ }
+
+ /**
+ * Creates a new SkeletonAnimationSet
object.
+ *
+ * @param jointsPerVertex Sets the amount of skeleton joints that can be linked to a single vertex via skinned weight values. For GPU-base animation, the maximum allowed value is 4. Defaults to 4.
+ */
+ constructor(jointsPerVertex:number /*uint*/ = 4)
+ {
+ super();
+
+ this._jointsPerVertex = jointsPerVertex;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALVertexCode(shaderObject:ShaderObjectBase):string
+ {
+ var len:number /*uint*/ = shaderObject.animatableAttributes.length;
+
+ var indexOffset0:number /*uint*/ = shaderObject.numUsedVertexConstants;
+ var indexOffset1:number /*uint*/ = indexOffset0 + 1;
+ var indexOffset2:number /*uint*/ = indexOffset0 + 2;
+ var indexStream:string = "va" + shaderObject.numUsedStreams;
+ var weightStream:string = "va" + (shaderObject.numUsedStreams + 1);
+ var indices:Array = [ indexStream + ".x", indexStream + ".y", indexStream + ".z", indexStream + ".w" ];
+ var weights:Array = [ weightStream + ".x", weightStream + ".y", weightStream + ".z", weightStream + ".w" ];
+ var temp1:string = this._pFindTempReg(shaderObject.animationTargetRegisters);
+ var temp2:string = this._pFindTempReg(shaderObject.animationTargetRegisters, temp1);
+ var dot:string = "dp4";
+ var code:string = "";
+
+ for (var i:number /*uint*/ = 0; i < len; ++i) {
+
+ var src:string = shaderObject.animatableAttributes[i];
+
+ for (var j:number /*uint*/ = 0; j < this._jointsPerVertex; ++j) {
+ code += dot + " " + temp1 + ".x, " + src + ", vc[" + indices[j] + "+" + indexOffset0 + "]\n" +
+ dot + " " + temp1 + ".y, " + src + ", vc[" + indices[j] + "+" + indexOffset1 + "]\n" +
+ dot + " " + temp1 + ".z, " + src + ", vc[" + indices[j] + "+" + indexOffset2 + "]\n" +
+ "mov " + temp1 + ".w, " + src + ".w\n" +
+ "mul " + temp1 + ", " + temp1 + ", " + weights[j] + "\n"; // apply weight
+
+ // add or mov to target. Need to write to a temp reg first, because an output can be a target
+ if (j == 0)
+ code += "mov " + temp2 + ", " + temp1 + "\n"; else
+ code += "add " + temp2 + ", " + temp2 + ", " + temp1 + "\n";
+ }
+ // switch to dp3 once positions have been transformed, from now on, it should only be vectors instead of points
+ dot = "dp3";
+ code += "mov " + shaderObject.animationTargetRegisters[i] + ", " + temp2 + "\n";
+ }
+
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public activate(shaderObject:ShaderObjectBase, stage:Stage)
+ {
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public deactivate(shaderObject:ShaderObjectBase, stage:Stage)
+ {
+// var streamOffset:number /*uint*/ = pass.numUsedStreams;
+// var context:IContextStageGL = stage.context;
+// context.setVertexBufferAt(streamOffset, null);
+// context.setVertexBufferAt(streamOffset + 1, null);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALFragmentCode(shaderObject:ShaderObjectBase, shadedTarget:string):string
+ {
+ return "";
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALUVCode(shaderObject:ShaderObjectBase):string
+ {
+ return "mov " + shaderObject.uvTarget + "," + shaderObject.uvSource + "\n";
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public doneAGALCode(shaderObject:ShaderObjectBase)
+ {
+
+ }
+}
+
+export = SkeletonAnimationSet;
\ No newline at end of file
diff --git a/lib/animators/SkeletonAnimator.js b/lib/animators/SkeletonAnimator.js
new file mode 100755
index 000000000..6b1010575
--- /dev/null
+++ b/lib/animators/SkeletonAnimator.js
@@ -0,0 +1,533 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var TriangleSubGeometry = require("awayjs-core/lib/core/base/TriangleSubGeometry");
+var SubGeometryEvent = require("awayjs-core/lib/events/SubGeometryEvent");
+var AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+var ContextGLProgramType = require("awayjs-stagegl/lib/core/stagegl/ContextGLProgramType");
+var JointPose = require("awayjs-renderergl/lib/animators/data/JointPose");
+var SkeletonPose = require("awayjs-renderergl/lib/animators/data/SkeletonPose");
+var AnimationStateEvent = require("awayjs-renderergl/lib/events/AnimationStateEvent");
+/**
+ * Provides an interface for assigning skeleton-based animation data sets to mesh-based entity objects
+ * and controlling the various available states of animation through an interative playhead that can be
+ * automatically updated or manually triggered.
+ */
+var SkeletonAnimator = (function (_super) {
+ __extends(SkeletonAnimator, _super);
+ /**
+ * Creates a new SkeletonAnimator
object.
+ *
+ * @param skeletonAnimationSet The animation data set containing the skeleton animations used by the animator.
+ * @param skeleton The skeleton object used for calculating the resulting global matrices for transforming skinned mesh data.
+ * @param forceCPU Optional value that only allows the animator to perform calculation on the CPU. Defaults to false.
+ */
+ function SkeletonAnimator(animationSet, skeleton, forceCPU) {
+ var _this = this;
+ if (forceCPU === void 0) { forceCPU = false; }
+ _super.call(this, animationSet);
+ this._globalPose = new SkeletonPose();
+ this._morphedSubGeometry = new Object();
+ this._morphedSubGeometryDirty = new Object();
+ this._skeleton = skeleton;
+ this._forceCPU = forceCPU;
+ this._jointsPerVertex = animationSet.jointsPerVertex;
+ this._numJoints = this._skeleton.numJoints;
+ this._globalMatrices = new Array(this._numJoints * 12);
+ var j = 0;
+ for (var i = 0; i < this._numJoints; ++i) {
+ this._globalMatrices[j++] = 1;
+ this._globalMatrices[j++] = 0;
+ this._globalMatrices[j++] = 0;
+ this._globalMatrices[j++] = 0;
+ this._globalMatrices[j++] = 0;
+ this._globalMatrices[j++] = 1;
+ this._globalMatrices[j++] = 0;
+ this._globalMatrices[j++] = 0;
+ this._globalMatrices[j++] = 0;
+ this._globalMatrices[j++] = 0;
+ this._globalMatrices[j++] = 1;
+ this._globalMatrices[j++] = 0;
+ }
+ this._onTransitionCompleteDelegate = function (event) { return _this.onTransitionComplete(event); };
+ this._onIndicesUpdateDelegate = function (event) { return _this.onIndicesUpdate(event); };
+ this._onVerticesUpdateDelegate = function (event) { return _this.onVerticesUpdate(event); };
+ }
+ Object.defineProperty(SkeletonAnimator.prototype, "globalMatrices", {
+ /**
+ * returns the calculated global matrices of the current skeleton pose.
+ *
+ * @see #globalPose
+ */
+ get: function () {
+ if (this._globalPropertiesDirty)
+ this.updateGlobalProperties();
+ return this._globalMatrices;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(SkeletonAnimator.prototype, "globalPose", {
+ /**
+ * returns the current skeleton pose output from the animator.
+ *
+ * @see away.animators.data.SkeletonPose
+ */
+ get: function () {
+ if (this._globalPropertiesDirty)
+ this.updateGlobalProperties();
+ return this._globalPose;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(SkeletonAnimator.prototype, "skeleton", {
+ /**
+ * Returns the skeleton object in use by the animator - this defines the number and heirarchy of joints used by the
+ * skinned geoemtry to which skeleon animator is applied.
+ */
+ get: function () {
+ return this._skeleton;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(SkeletonAnimator.prototype, "forceCPU", {
+ /**
+ * Indicates whether the skeleton animator is disabled by default for GPU rendering, something that allows the animator to perform calculation on the GPU.
+ * Defaults to false.
+ */
+ get: function () {
+ return this._forceCPU;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(SkeletonAnimator.prototype, "useCondensedIndices", {
+ /**
+ * Offers the option of enabling GPU accelerated animation on skeletons larger than 32 joints
+ * by condensing the number of joint index values required per mesh. Only applicable to
+ * skeleton animations that utilise more than one mesh object. Defaults to false.
+ */
+ get: function () {
+ return this._useCondensedIndices;
+ },
+ set: function (value) {
+ this._useCondensedIndices = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ SkeletonAnimator.prototype.clone = function () {
+ /* The cast to SkeletonAnimationSet should never fail, as _animationSet can only be set
+ through the constructor, which will only accept a SkeletonAnimationSet. */
+ return new SkeletonAnimator(this._pAnimationSet, this._skeleton, this._forceCPU);
+ };
+ /**
+ * Plays an animation state registered with the given name in the animation data set.
+ *
+ * @param name The data set name of the animation state to be played.
+ * @param transition An optional transition object that determines how the animator will transition from the currently active animation state.
+ * @param offset An option offset time (in milliseconds) that resets the state's internal clock to the absolute time of the animator plus the offset value. Required for non-looping animation states.
+ */
+ SkeletonAnimator.prototype.play = function (name, transition, offset) {
+ if (transition === void 0) { transition = null; }
+ if (offset === void 0) { offset = NaN; }
+ if (this._pActiveAnimationName == name)
+ return;
+ this._pActiveAnimationName = name;
+ if (!this._pAnimationSet.hasAnimation(name))
+ throw new Error("Animation root node " + name + " not found!");
+ if (transition && this._pActiveNode) {
+ //setup the transition
+ this._pActiveNode = transition.getAnimationNode(this, this._pActiveNode, this._pAnimationSet.getAnimation(name), this._pAbsoluteTime);
+ this._pActiveNode.addEventListener(AnimationStateEvent.TRANSITION_COMPLETE, this._onTransitionCompleteDelegate);
+ }
+ else
+ this._pActiveNode = this._pAnimationSet.getAnimation(name);
+ this._pActiveState = this.getAnimationState(this._pActiveNode);
+ if (this.updatePosition) {
+ //update straight away to reset position deltas
+ this._pActiveState.update(this._pAbsoluteTime);
+ this._pActiveState.positionDelta;
+ }
+ this._activeSkeletonState = this._pActiveState;
+ this.start();
+ //apply a time offset if specified
+ if (!isNaN(offset))
+ this.reset(name, offset);
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonAnimator.prototype.setRenderState = function (shaderObject, renderable, stage, camera, vertexConstantOffset /*int*/, vertexStreamOffset /*int*/) {
+ // do on request of globalProperties
+ if (this._globalPropertiesDirty)
+ this.updateGlobalProperties();
+ var subGeometry = renderable.subMesh.subGeometry;
+ subGeometry.useCondensedIndices = this._useCondensedIndices;
+ if (this._useCondensedIndices) {
+ // using a condensed data set
+ this.updateCondensedMatrices(subGeometry.condensedIndexLookUp, subGeometry.numCondensedJoints);
+ stage.context.setProgramConstantsFromArray(ContextGLProgramType.VERTEX, vertexConstantOffset, this._condensedMatrices, subGeometry.numCondensedJoints * 3);
+ }
+ else {
+ if (this._pAnimationSet.usesCPU) {
+ if (this._morphedSubGeometryDirty[subGeometry.id])
+ this.morphSubGeometry(renderable, subGeometry);
+ return;
+ }
+ stage.context.setProgramConstantsFromArray(ContextGLProgramType.VERTEX, vertexConstantOffset, this._globalMatrices, this._numJoints * 3);
+ }
+ stage.context.activateBuffer(vertexStreamOffset, renderable.getVertexData(TriangleSubGeometry.JOINT_INDEX_DATA), renderable.getVertexOffset(TriangleSubGeometry.JOINT_INDEX_DATA), renderable.JOINT_INDEX_FORMAT);
+ stage.context.activateBuffer(vertexStreamOffset + 1, renderable.getVertexData(TriangleSubGeometry.JOINT_WEIGHT_DATA), renderable.getVertexOffset(TriangleSubGeometry.JOINT_WEIGHT_DATA), renderable.JOINT_WEIGHT_FORMAT);
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonAnimator.prototype.testGPUCompatibility = function (shaderObject) {
+ if (!this._useCondensedIndices && (this._forceCPU || this._jointsPerVertex > 4 || shaderObject.numUsedVertexConstants + this._numJoints * 3 > 128))
+ this._pAnimationSet.cancelGPUCompatibility();
+ };
+ /**
+ * Applies the calculated time delta to the active animation state node or state transition object.
+ */
+ SkeletonAnimator.prototype._pUpdateDeltaTime = function (dt) {
+ _super.prototype._pUpdateDeltaTime.call(this, dt);
+ //invalidate pose matrices
+ this._globalPropertiesDirty = true;
+ //trigger geometry invalidation if using CPU animation
+ if (this._pAnimationSet.usesCPU)
+ for (var key in this._morphedSubGeometryDirty)
+ this._morphedSubGeometryDirty[key] = true;
+ };
+ SkeletonAnimator.prototype.updateCondensedMatrices = function (condensedIndexLookUp /*uint*/, numJoints /*uint*/) {
+ var i = 0, j = 0;
+ var len /*uint*/;
+ var srcIndex /*uint*/;
+ this._condensedMatrices = new Array();
+ do {
+ srcIndex = condensedIndexLookUp[i] * 4;
+ len = srcIndex + 12;
+ while (srcIndex < len)
+ this._condensedMatrices[j++] = this._globalMatrices[srcIndex++];
+ } while (++i < numJoints);
+ };
+ SkeletonAnimator.prototype.updateGlobalProperties = function () {
+ this._globalPropertiesDirty = false;
+ //get global pose
+ this.localToGlobalPose(this._activeSkeletonState.getSkeletonPose(this._skeleton), this._globalPose, this._skeleton);
+ // convert pose to matrix
+ var mtxOffset = 0;
+ var globalPoses = this._globalPose.jointPoses;
+ var raw;
+ var ox, oy, oz, ow;
+ var xy2, xz2, xw2;
+ var yz2, yw2, zw2;
+ var n11, n12, n13;
+ var n21, n22, n23;
+ var n31, n32, n33;
+ var m11, m12, m13, m14;
+ var m21, m22, m23, m24;
+ var m31, m32, m33, m34;
+ var joints = this._skeleton.joints;
+ var pose;
+ var quat;
+ var vec;
+ var t;
+ for (var i = 0; i < this._numJoints; ++i) {
+ pose = globalPoses[i];
+ quat = pose.orientation;
+ vec = pose.translation;
+ ox = quat.x;
+ oy = quat.y;
+ oz = quat.z;
+ ow = quat.w;
+ xy2 = (t = 2.0 * ox) * oy;
+ xz2 = t * oz;
+ xw2 = t * ow;
+ yz2 = (t = 2.0 * oy) * oz;
+ yw2 = t * ow;
+ zw2 = 2.0 * oz * ow;
+ yz2 = 2.0 * oy * oz;
+ yw2 = 2.0 * oy * ow;
+ zw2 = 2.0 * oz * ow;
+ ox *= ox;
+ oy *= oy;
+ oz *= oz;
+ ow *= ow;
+ n11 = (t = ox - oy) - oz + ow;
+ n12 = xy2 - zw2;
+ n13 = xz2 + yw2;
+ n21 = xy2 + zw2;
+ n22 = -t - oz + ow;
+ n23 = yz2 - xw2;
+ n31 = xz2 - yw2;
+ n32 = yz2 + xw2;
+ n33 = -ox - oy + oz + ow;
+ // prepend inverse bind pose
+ raw = joints[i].inverseBindPose;
+ m11 = raw[0];
+ m12 = raw[4];
+ m13 = raw[8];
+ m14 = raw[12];
+ m21 = raw[1];
+ m22 = raw[5];
+ m23 = raw[9];
+ m24 = raw[13];
+ m31 = raw[2];
+ m32 = raw[6];
+ m33 = raw[10];
+ m34 = raw[14];
+ this._globalMatrices[mtxOffset] = n11 * m11 + n12 * m21 + n13 * m31;
+ this._globalMatrices[mtxOffset + 1] = n11 * m12 + n12 * m22 + n13 * m32;
+ this._globalMatrices[mtxOffset + 2] = n11 * m13 + n12 * m23 + n13 * m33;
+ this._globalMatrices[mtxOffset + 3] = n11 * m14 + n12 * m24 + n13 * m34 + vec.x;
+ this._globalMatrices[mtxOffset + 4] = n21 * m11 + n22 * m21 + n23 * m31;
+ this._globalMatrices[mtxOffset + 5] = n21 * m12 + n22 * m22 + n23 * m32;
+ this._globalMatrices[mtxOffset + 6] = n21 * m13 + n22 * m23 + n23 * m33;
+ this._globalMatrices[mtxOffset + 7] = n21 * m14 + n22 * m24 + n23 * m34 + vec.y;
+ this._globalMatrices[mtxOffset + 8] = n31 * m11 + n32 * m21 + n33 * m31;
+ this._globalMatrices[mtxOffset + 9] = n31 * m12 + n32 * m22 + n33 * m32;
+ this._globalMatrices[mtxOffset + 10] = n31 * m13 + n32 * m23 + n33 * m33;
+ this._globalMatrices[mtxOffset + 11] = n31 * m14 + n32 * m24 + n33 * m34 + vec.z;
+ mtxOffset = mtxOffset + 12;
+ }
+ };
+ SkeletonAnimator.prototype.getRenderableSubGeometry = function (renderable, sourceSubGeometry) {
+ this._morphedSubGeometryDirty[sourceSubGeometry.id] = true;
+ //early out for GPU animations
+ if (!this._pAnimationSet.usesCPU)
+ return sourceSubGeometry;
+ var targetSubGeometry;
+ if (!(targetSubGeometry = this._morphedSubGeometry[sourceSubGeometry.id])) {
+ //not yet stored
+ targetSubGeometry = this._morphedSubGeometry[sourceSubGeometry.id] = sourceSubGeometry.clone();
+ //turn off auto calculations on the morphed geometry
+ targetSubGeometry.autoDeriveNormals = false;
+ targetSubGeometry.autoDeriveTangents = false;
+ targetSubGeometry.autoDeriveUVs = false;
+ //add event listeners for any changes in UV values on the source geometry
+ sourceSubGeometry.addEventListener(SubGeometryEvent.INDICES_UPDATED, this._onIndicesUpdateDelegate);
+ sourceSubGeometry.addEventListener(SubGeometryEvent.VERTICES_UPDATED, this._onVerticesUpdateDelegate);
+ }
+ return targetSubGeometry;
+ };
+ /**
+ * If the animation can't be performed on GPU, transform vertices manually
+ * @param subGeom The subgeometry containing the weights and joint index data per vertex.
+ * @param pass The material pass for which we need to transform the vertices
+ */
+ SkeletonAnimator.prototype.morphSubGeometry = function (renderable, sourceSubGeometry) {
+ this._morphedSubGeometryDirty[sourceSubGeometry.id] = false;
+ var sourcePositions = sourceSubGeometry.positions;
+ var sourceNormals = sourceSubGeometry.vertexNormals;
+ var sourceTangents = sourceSubGeometry.vertexTangents;
+ var jointIndices = sourceSubGeometry.jointIndices;
+ var jointWeights = sourceSubGeometry.jointWeights;
+ var targetSubGeometry = this._morphedSubGeometry[sourceSubGeometry.id];
+ var targetPositions = targetSubGeometry.positions;
+ var targetNormals = targetSubGeometry.vertexNormals;
+ var targetTangents = targetSubGeometry.vertexTangents;
+ var index = 0;
+ var j = 0;
+ var k /*uint*/;
+ var vx, vy, vz;
+ var nx, ny, nz;
+ var tx, ty, tz;
+ var len = sourcePositions.length;
+ var weight;
+ var vertX, vertY, vertZ;
+ var normX, normY, normZ;
+ var tangX, tangY, tangZ;
+ var m11, m12, m13, m14;
+ var m21, m22, m23, m24;
+ var m31, m32, m33, m34;
+ while (index < len) {
+ vertX = sourcePositions[index];
+ vertY = sourcePositions[index + 1];
+ vertZ = sourcePositions[index + 2];
+ normX = sourceNormals[index];
+ normY = sourceNormals[index + 1];
+ normZ = sourceNormals[index + 2];
+ tangX = sourceTangents[index];
+ tangY = sourceTangents[index + 1];
+ tangZ = sourceTangents[index + 2];
+ vx = 0;
+ vy = 0;
+ vz = 0;
+ nx = 0;
+ ny = 0;
+ nz = 0;
+ tx = 0;
+ ty = 0;
+ tz = 0;
+ k = 0;
+ while (k < this._jointsPerVertex) {
+ weight = jointWeights[j];
+ if (weight > 0) {
+ // implicit /3*12 (/3 because indices are multiplied by 3 for gpu matrix access, *12 because it's the matrix size)
+ var mtxOffset = jointIndices[j++] << 2;
+ m11 = this._globalMatrices[mtxOffset];
+ m12 = this._globalMatrices[mtxOffset + 1];
+ m13 = this._globalMatrices[mtxOffset + 2];
+ m14 = this._globalMatrices[mtxOffset + 3];
+ m21 = this._globalMatrices[mtxOffset + 4];
+ m22 = this._globalMatrices[mtxOffset + 5];
+ m23 = this._globalMatrices[mtxOffset + 6];
+ m24 = this._globalMatrices[mtxOffset + 7];
+ m31 = this._globalMatrices[mtxOffset + 8];
+ m32 = this._globalMatrices[mtxOffset + 9];
+ m33 = this._globalMatrices[mtxOffset + 10];
+ m34 = this._globalMatrices[mtxOffset + 11];
+ vx += weight * (m11 * vertX + m12 * vertY + m13 * vertZ + m14);
+ vy += weight * (m21 * vertX + m22 * vertY + m23 * vertZ + m24);
+ vz += weight * (m31 * vertX + m32 * vertY + m33 * vertZ + m34);
+ nx += weight * (m11 * normX + m12 * normY + m13 * normZ);
+ ny += weight * (m21 * normX + m22 * normY + m23 * normZ);
+ nz += weight * (m31 * normX + m32 * normY + m33 * normZ);
+ tx += weight * (m11 * tangX + m12 * tangY + m13 * tangZ);
+ ty += weight * (m21 * tangX + m22 * tangY + m23 * tangZ);
+ tz += weight * (m31 * tangX + m32 * tangY + m33 * tangZ);
+ ++k;
+ }
+ else {
+ j += (this._jointsPerVertex - k);
+ k = this._jointsPerVertex;
+ }
+ }
+ targetPositions[index] = vx;
+ targetPositions[index + 1] = vy;
+ targetPositions[index + 2] = vz;
+ targetNormals[index] = nx;
+ targetNormals[index + 1] = ny;
+ targetNormals[index + 2] = nz;
+ targetTangents[index] = tx;
+ targetTangents[index + 1] = ty;
+ targetTangents[index + 2] = tz;
+ index += 3;
+ }
+ targetSubGeometry.updatePositions(targetPositions);
+ targetSubGeometry.updateVertexNormals(targetNormals);
+ targetSubGeometry.updateVertexTangents(targetTangents);
+ };
+ /**
+ * Converts a local hierarchical skeleton pose to a global pose
+ * @param targetPose The SkeletonPose object that will contain the global pose.
+ * @param skeleton The skeleton containing the joints, and as such, the hierarchical data to transform to global poses.
+ */
+ SkeletonAnimator.prototype.localToGlobalPose = function (sourcePose, targetPose, skeleton) {
+ var globalPoses = targetPose.jointPoses;
+ var globalJointPose;
+ var joints = skeleton.joints;
+ var len = sourcePose.numJointPoses;
+ var jointPoses = sourcePose.jointPoses;
+ var parentIndex /*int*/;
+ var joint;
+ var parentPose;
+ var pose;
+ var or;
+ var tr;
+ var t;
+ var q;
+ var x1, y1, z1, w1;
+ var x2, y2, z2, w2;
+ var x3, y3, z3;
+ // :s
+ if (globalPoses.length != len)
+ globalPoses.length = len;
+ for (var i = 0; i < len; ++i) {
+ globalJointPose = globalPoses[i];
+ if (globalJointPose == null)
+ globalJointPose = globalPoses[i] = new JointPose();
+ joint = joints[i];
+ parentIndex = joint.parentIndex;
+ pose = jointPoses[i];
+ q = globalJointPose.orientation;
+ t = globalJointPose.translation;
+ if (parentIndex < 0) {
+ tr = pose.translation;
+ or = pose.orientation;
+ q.x = or.x;
+ q.y = or.y;
+ q.z = or.z;
+ q.w = or.w;
+ t.x = tr.x;
+ t.y = tr.y;
+ t.z = tr.z;
+ }
+ else {
+ // append parent pose
+ parentPose = globalPoses[parentIndex];
+ // rotate point
+ or = parentPose.orientation;
+ tr = pose.translation;
+ x2 = or.x;
+ y2 = or.y;
+ z2 = or.z;
+ w2 = or.w;
+ x3 = tr.x;
+ y3 = tr.y;
+ z3 = tr.z;
+ w1 = -x2 * x3 - y2 * y3 - z2 * z3;
+ x1 = w2 * x3 + y2 * z3 - z2 * y3;
+ y1 = w2 * y3 - x2 * z3 + z2 * x3;
+ z1 = w2 * z3 + x2 * y3 - y2 * x3;
+ // append parent translation
+ tr = parentPose.translation;
+ t.x = -w1 * x2 + x1 * w2 - y1 * z2 + z1 * y2 + tr.x;
+ t.y = -w1 * y2 + x1 * z2 + y1 * w2 - z1 * x2 + tr.y;
+ t.z = -w1 * z2 - x1 * y2 + y1 * x2 + z1 * w2 + tr.z;
+ // append parent orientation
+ x1 = or.x;
+ y1 = or.y;
+ z1 = or.z;
+ w1 = or.w;
+ or = pose.orientation;
+ x2 = or.x;
+ y2 = or.y;
+ z2 = or.z;
+ w2 = or.w;
+ q.w = w1 * w2 - x1 * x2 - y1 * y2 - z1 * z2;
+ q.x = w1 * x2 + x1 * w2 + y1 * z2 - z1 * y2;
+ q.y = w1 * y2 - x1 * z2 + y1 * w2 + z1 * x2;
+ q.z = w1 * z2 + x1 * y2 - y1 * x2 + z1 * w2;
+ }
+ }
+ };
+ SkeletonAnimator.prototype.onTransitionComplete = function (event) {
+ if (event.type == AnimationStateEvent.TRANSITION_COMPLETE) {
+ event.animationNode.removeEventListener(AnimationStateEvent.TRANSITION_COMPLETE, this._onTransitionCompleteDelegate);
+ //if this is the current active state transition, revert control to the active node
+ if (this._pActiveState == event.animationState) {
+ this._pActiveNode = this._pAnimationSet.getAnimation(this._pActiveAnimationName);
+ this._pActiveState = this.getAnimationState(this._pActiveNode);
+ this._activeSkeletonState = this._pActiveState;
+ }
+ }
+ };
+ SkeletonAnimator.prototype.onIndicesUpdate = function (event) {
+ var subGeometry = event.target;
+ this._morphedSubGeometry[subGeometry.id].updateIndices(subGeometry.indices);
+ };
+ SkeletonAnimator.prototype.onVerticesUpdate = function (event) {
+ var subGeometry = event.target;
+ var morphGeometry = this._morphedSubGeometry[subGeometry.id];
+ switch (event.dataType) {
+ case TriangleSubGeometry.UV_DATA:
+ morphGeometry.updateUVs(subGeometry.uvs);
+ case TriangleSubGeometry.SECONDARY_UV_DATA:
+ morphGeometry.updateUVs(subGeometry.secondaryUVs);
+ }
+ };
+ return SkeletonAnimator;
+})(AnimatorBase);
+module.exports = SkeletonAnimator;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/skeletonanimator.ts"],"names":["SkeletonAnimator","SkeletonAnimator.constructor","SkeletonAnimator.globalMatrices","SkeletonAnimator.globalPose","SkeletonAnimator.skeleton","SkeletonAnimator.forceCPU","SkeletonAnimator.useCondensedIndices","SkeletonAnimator.clone","SkeletonAnimator.play","SkeletonAnimator.setRenderState","SkeletonAnimator.testGPUCompatibility","SkeletonAnimator._pUpdateDeltaTime","SkeletonAnimator.updateCondensedMatrices","SkeletonAnimator.updateGlobalProperties","SkeletonAnimator.getRenderableSubGeometry","SkeletonAnimator.morphSubGeometry","SkeletonAnimator.localToGlobalPose","SkeletonAnimator.onTransitionComplete","SkeletonAnimator.onIndicesUpdate","SkeletonAnimator.onVerticesUpdate"],"mappings":";;;;;;AACA,IAAO,mBAAmB,WAAc,+CAA+C,CAAC,CAAC;AAKzF,IAAO,gBAAgB,WAAe,yCAAyC,CAAC,CAAC;AAEjF,IAAO,YAAY,WAAgB,2CAA2C,CAAC,CAAC;AAIhF,IAAO,oBAAoB,WAAc,sDAAsD,CAAC,CAAC;AAKjG,IAAO,SAAS,WAAgB,gDAAgD,CAAC,CAAC;AAGlF,IAAO,YAAY,WAAgB,mDAAmD,CAAC,CAAC;AAGxF,IAAO,mBAAmB,WAAc,kDAAkD,CAAC,CAAC;AAE5F,AAKA;;;;GADG;IACG,gBAAgB;IAASA,UAAzBA,gBAAgBA,UAAqBA;IA+E1CA;;;;;;OAMGA;IACHA,SAtFKA,gBAAgBA,CAsFTA,YAAiCA,EAAEA,QAAiBA,EAAEA,QAAwBA;QAtF3FC,iBAqlBCA;QA/fkEA,wBAAwBA,GAAxBA,gBAAwBA;QAEzFA,kBAAMA,YAAYA,CAACA,CAACA;QArFbA,gBAAWA,GAAgBA,IAAIA,YAAYA,EAAEA,CAACA;QAG9CA,wBAAmBA,GAAUA,IAAIA,MAAMA,EAAEA,CAACA;QAC1CA,6BAAwBA,GAAUA,IAAIA,MAAMA,EAAEA,CAACA;QAmFtDA,IAAIA,CAACA,SAASA,GAAGA,QAAQA,CAACA;QAC1BA,IAAIA,CAACA,SAASA,GAAGA,QAAQA,CAACA;QAC1BA,IAAIA,CAACA,gBAAgBA,GAAGA,YAAYA,CAACA,eAAeA,CAACA;QAErDA,IAAIA,CAACA,UAAUA,GAAGA,IAAIA,CAACA,SAASA,CAACA,SAASA,CAACA;QAC3CA,IAAIA,CAACA,eAAeA,GAAGA,IAAIA,KAAKA,CAASA,IAAIA,CAACA,UAAUA,GAACA,EAAEA,CAACA,CAACA;QAE7DA,IAAIA,CAACA,GAAkBA,CAACA,CAACA;QACzBA,GAAGA,CAACA,CAACA,GAAGA,CAACA,CAACA,GAAmBA,CAACA,EAAEA,CAACA,GAAGA,IAAIA,CAACA,UAAUA,EAAEA,EAAEA,CAACA,EAAEA,CAACA;YAC1DA,IAAIA,CAACA,eAAeA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,CAACA;YAC9BA,IAAIA,CAACA,eAAeA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,CAACA;YAC9BA,IAAIA,CAACA,eAAeA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,CAACA;YAC9BA,IAAIA,CAACA,eAAeA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,CAACA;YAC9BA,IAAIA,CAACA,eAAeA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,CAACA;YAC9BA,IAAIA,CAACA,eAAeA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,CAACA;YAC9BA,IAAIA,CAACA,eAAeA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,CAACA;YAC9BA,IAAIA,CAACA,eAAeA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,CAACA;YAC9BA,IAAIA,CAACA,eAAeA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,CAACA;YAC9BA,IAAIA,CAACA,eAAeA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,CAACA;YAC9BA,IAAIA,CAACA,eAAeA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,CAACA;YAC9BA,IAAIA,CAACA,eAAeA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,CAACA;QAC/BA,CAACA;QAEDA,IAAIA,CAACA,6BAA6BA,GAAGA,UAACA,KAAyBA,IAAKA,OAAAA,KAAIA,CAACA,oBAAoBA,CAACA,KAAKA,CAACA,EAAhCA,CAAgCA,CAACA;QACrGA,IAAIA,CAACA,wBAAwBA,GAAGA,UAACA,KAAsBA,IAAKA,OAAAA,KAAIA,CAACA,eAAeA,CAACA,KAAKA,CAACA,EAA3BA,CAA2BA,CAACA;QACxFA,IAAIA,CAACA,yBAAyBA,GAAGA,UAACA,KAAsBA,IAAKA,OAAAA,KAAIA,CAACA,gBAAgBA,CAACA,KAAKA,CAACA,EAA5BA,CAA4BA,CAACA;IAC3FA,CAACA;IA3FDD,sBAAWA,4CAAcA;QALzBA;;;;WAIGA;aACHA;YAECE,EAAEA,CAACA,CAACA,IAAIA,CAACA,sBAAsBA,CAACA;gBAC/BA,IAAIA,CAACA,sBAAsBA,EAAEA,CAACA;YAE/BA,MAAMA,CAACA,IAAIA,CAACA,eAAeA,CAACA;QAC7BA,CAACA;;;OAAAF;IAODA,sBAAWA,wCAAUA;QALrBA;;;;WAIGA;aACHA;YAECG,EAAEA,CAACA,CAACA,IAAIA,CAACA,sBAAsBA,CAACA;gBAC/BA,IAAIA,CAACA,sBAAsBA,EAAEA,CAACA;YAE/BA,MAAMA,CAACA,IAAIA,CAACA,WAAWA,CAACA;QACzBA,CAACA;;;OAAAH;IAMDA,sBAAWA,sCAAQA;QAJnBA;;;WAGGA;aACHA;YAECI,MAAMA,CAACA,IAAIA,CAACA,SAASA,CAACA;QACvBA,CAACA;;;OAAAJ;IAMDA,sBAAWA,sCAAQA;QAJnBA;;;WAGGA;aACHA;YAECK,MAAMA,CAACA,IAAIA,CAACA,SAASA,CAACA;QACvBA,CAACA;;;OAAAL;IAODA,sBAAWA,iDAAmBA;QAL9BA;;;;WAIGA;aACHA;YAECM,MAAMA,CAACA,IAAIA,CAACA,oBAAoBA,CAACA;QAClCA,CAACA;aAEDN,UAA+BA,KAAaA;YAE3CM,IAAIA,CAACA,oBAAoBA,GAAGA,KAAKA,CAACA;QACnCA,CAACA;;;OALAN;IA8CDA;;OAEGA;IACIA,gCAAKA,GAAZA;QAECO,AAEAA;mFAD2EA;QAC3EA,MAAMA,CAACA,IAAIA,gBAAgBA,CAAwBA,IAAIA,CAACA,cAAcA,EAAEA,IAAIA,CAACA,SAASA,EAAEA,IAAIA,CAACA,SAASA,CAACA,CAACA;IACzGA,CAACA;IAEDP;;;;;;OAMGA;IACIA,+BAAIA,GAAXA,UAAYA,IAAWA,EAAEA,UAAsCA,EAAEA,MAAmBA;QAA3DQ,0BAAsCA,GAAtCA,iBAAsCA;QAAEA,sBAAmBA,GAAnBA,YAAmBA;QAEnFA,EAAEA,CAACA,CAACA,IAAIA,CAACA,qBAAqBA,IAAIA,IAAIA,CAACA;YACtCA,MAAMA,CAACA;QAERA,IAAIA,CAACA,qBAAqBA,GAAGA,IAAIA,CAACA;QAElCA,EAAEA,CAACA,CAACA,CAACA,IAAIA,CAACA,cAAcA,CAACA,YAAYA,CAACA,IAAIA,CAACA,CAACA;YAC3CA,MAAMA,IAAIA,KAAKA,CAACA,sBAAsBA,GAAGA,IAAIA,GAAGA,aAAaA,CAACA,CAACA;QAEhEA,EAAEA,CAACA,CAACA,UAAUA,IAAIA,IAAIA,CAACA,YAAYA,CAACA,CAACA,CAACA;YACrCA,AACAA,sBADsBA;YACtBA,IAAIA,CAACA,YAAYA,GAAGA,UAAUA,CAACA,gBAAgBA,CAACA,IAAIA,EAAEA,IAAIA,CAACA,YAAYA,EAAEA,IAAIA,CAACA,cAAcA,CAACA,YAAYA,CAACA,IAAIA,CAACA,EAAEA,IAAIA,CAACA,cAAcA,CAACA,CAACA;YACtIA,IAAIA,CAACA,YAAYA,CAACA,gBAAgBA,CAACA,mBAAmBA,CAACA,mBAAmBA,EAAEA,IAAIA,CAACA,6BAA6BA,CAACA,CAACA;QACjHA,CAACA;QAACA,IAAIA;YACLA,IAAIA,CAACA,YAAYA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,YAAYA,CAACA,IAAIA,CAACA,CAACA;QAE5DA,IAAIA,CAACA,aAAaA,GAAGA,IAAIA,CAACA,iBAAiBA,CAACA,IAAIA,CAACA,YAAYA,CAACA,CAACA;QAE/DA,EAAEA,CAACA,CAACA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA;YACzBA,AACAA,+CAD+CA;YAC/CA,IAAIA,CAACA,aAAaA,CAACA,MAAMA,CAACA,IAAIA,CAACA,cAAcA,CAACA,CAACA;YAC/CA,IAAIA,CAACA,aAAaA,CAACA,aAAaA,CAACA;QAClCA,CAACA;QAEDA,IAAIA,CAACA,oBAAoBA,GAA6BA,IAAIA,CAACA,aAAaA,CAACA;QAEzEA,IAAIA,CAACA,KAAKA,EAAEA,CAACA;QAEbA,AACAA,kCADkCA;QAClCA,EAAEA,CAACA,CAACA,CAACA,KAAKA,CAACA,MAAMA,CAACA,CAACA;YAClBA,IAAIA,CAACA,KAAKA,CAACA,IAAIA,EAAEA,MAAMA,CAACA,CAACA;IAC3BA,CAACA;IAEDR;;OAEGA;IACIA,yCAAcA,GAArBA,UAAsBA,YAA6BA,EAAEA,UAAyBA,EAAEA,KAAWA,EAAEA,MAAaA,EAAEA,oBAAoBA,CAAQA,OAADA,AAAQA,EAAEA,kBAAkBA,CAAQA,OAADA,AAAQA;QAEjLS,AACAA,oCADoCA;QACpCA,EAAEA,CAACA,CAACA,IAAIA,CAACA,sBAAsBA,CAACA;YAC/BA,IAAIA,CAACA,sBAAsBA,EAAEA,CAACA;QAE/BA,IAAIA,WAAWA,GAA6FA,UAAWA,CAACA,OAAQA,CAACA,WAAWA,CAACA;QAE7IA,WAAWA,CAACA,mBAAmBA,GAAGA,IAAIA,CAACA,oBAAoBA,CAACA;QAE5DA,EAAEA,CAACA,CAACA,IAAIA,CAACA,oBAAoBA,CAACA,CAACA,CAACA;YAC/BA,AACAA,6BAD6BA;YAC7BA,IAAIA,CAACA,uBAAuBA,CAACA,WAAWA,CAACA,oBAAoBA,EAAEA,WAAWA,CAACA,kBAAkBA,CAACA,CAACA;YAC5EA,KAAKA,CAACA,OAAQA,CAACA,4BAA4BA,CAACA,oBAAoBA,CAACA,MAAMA,EAAEA,oBAAoBA,EAAEA,IAAIA,CAACA,kBAAkBA,EAAEA,WAAWA,CAACA,kBAAkBA,GAACA,CAACA,CAACA,CAACA;QAC9KA,CAACA;QAACA,IAAIA,CAACA,CAACA;YACPA,EAAEA,CAACA,CAACA,IAAIA,CAACA,cAAcA,CAACA,OAAOA,CAACA,CAACA,CAACA;gBACjCA,EAAEA,CAACA,CAACA,IAAIA,CAACA,wBAAwBA,CAACA,WAAWA,CAACA,EAAEA,CAACA,CAACA;oBACjDA,IAAIA,CAACA,gBAAgBA,CAA6BA,UAAUA,EAAEA,WAAWA,CAACA,CAACA;gBAE5EA,MAAMA,CAAAA;YACPA,CAACA;YACkBA,KAAKA,CAACA,OAAQA,CAACA,4BAA4BA,CAACA,oBAAoBA,CAACA,MAAMA,EAAEA,oBAAoBA,EAAEA,IAAIA,CAACA,eAAeA,EAAEA,IAAIA,CAACA,UAAUA,GAACA,CAACA,CAACA,CAACA;QAC5JA,CAACA;QAEkBA,KAAKA,CAACA,OAAQA,CAACA,cAAcA,CAACA,kBAAkBA,EAAEA,UAAUA,CAACA,aAAaA,CAACA,mBAAmBA,CAACA,gBAAgBA,CAACA,EAAEA,UAAUA,CAACA,eAAeA,CAACA,mBAAmBA,CAACA,gBAAgBA,CAACA,EAAEA,UAAUA,CAACA,kBAAkBA,CAACA,CAACA;QACnNA,KAAKA,CAACA,OAAQA,CAACA,cAAcA,CAACA,kBAAkBA,GAAGA,CAACA,EAAEA,UAAUA,CAACA,aAAaA,CAACA,mBAAmBA,CAACA,iBAAiBA,CAACA,EAAEA,UAAUA,CAACA,eAAeA,CAACA,mBAAmBA,CAACA,iBAAiBA,CAACA,EAAEA,UAAUA,CAACA,mBAAmBA,CAACA,CAACA;IAC9OA,CAACA;IAEDT;;OAEGA;IACIA,+CAAoBA,GAA3BA,UAA4BA,YAA6BA;QAExDU,EAAEA,CAACA,CAACA,CAACA,IAAIA,CAACA,oBAAoBA,IAAIA,CAACA,IAAIA,CAACA,SAASA,IAAIA,IAAIA,CAACA,gBAAgBA,GAAGA,CAACA,IAAIA,YAAYA,CAACA,sBAAsBA,GAAGA,IAAIA,CAACA,UAAUA,GAACA,CAACA,GAAGA,GAAGA,CAACA,CAACA;YAChJA,IAAIA,CAACA,cAAcA,CAACA,sBAAsBA,EAAEA,CAACA;IAC/CA,CAACA;IAEDV;;OAEGA;IACIA,4CAAiBA,GAAxBA,UAAyBA,EAASA;QAEjCW,gBAAKA,CAACA,iBAAiBA,YAACA,EAAEA,CAACA,CAACA;QAE5BA,AACAA,0BAD0BA;QAC1BA,IAAIA,CAACA,sBAAsBA,GAAGA,IAAIA,CAACA;QAEnCA,AACAA,sDADsDA;QACtDA,EAAEA,CAACA,CAACA,IAAIA,CAACA,cAAcA,CAACA,OAAOA,CAACA;YAC/BA,GAAGA,CAACA,CAACA,GAAGA,CAACA,GAAGA,IAAIA,IAAIA,CAACA,wBAAwBA,CAACA;gBAC7CA,IAAIA,CAACA,wBAAwBA,CAACA,GAAGA,CAACA,GAAGA,IAAIA,CAACA;IAC7CA,CAACA;IAEOX,kDAAuBA,GAA/BA,UAAgCA,oBAAoBA,CAAeA,QAADA,AAASA,EAAEA,SAASA,CAAQA,QAADA,AAASA;QAErGY,IAAIA,CAACA,GAAmBA,CAACA,EAAEA,CAACA,GAAmBA,CAACA,CAACA;QACjDA,IAAIA,GAAGA,CAAQA,QAADA,AAASA,CAACA;QACxBA,IAAIA,QAAQA,CAAQA,QAADA,AAASA,CAACA;QAE7BA,IAAIA,CAACA,kBAAkBA,GAAGA,IAAIA,KAAKA,EAAUA,CAACA;QAE9CA,GAAGA,CAACA;YACHA,QAAQA,GAAGA,oBAAoBA,CAACA,CAACA,CAACA,GAACA,CAACA,CAACA;YACrCA,GAAGA,GAAGA,QAAQA,GAAGA,EAAEA,CAACA;YAEpBA,OAAOA,QAAQA,GAAGA,GAAGA;gBACpBA,IAAIA,CAACA,kBAAkBA,CAACA,CAACA,EAAEA,CAACA,GAAGA,IAAIA,CAACA,eAAeA,CAACA,QAAQA,EAAEA,CAACA,CAACA;QAClEA,CAACA,QAAQA,EAAEA,CAACA,GAAGA,SAASA,EAAEA;IAC3BA,CAACA;IAEOZ,iDAAsBA,GAA9BA;QAECa,IAAIA,CAACA,sBAAsBA,GAAGA,KAAKA,CAACA;QAEpCA,AACAA,iBADiBA;QACjBA,IAAIA,CAACA,iBAAiBA,CAACA,IAAIA,CAACA,oBAAoBA,CAACA,eAAeA,CAACA,IAAIA,CAACA,SAASA,CAACA,EAAEA,IAAIA,CAACA,WAAWA,EAAEA,IAAIA,CAACA,SAASA,CAACA,CAACA;QAEpHA,AACAA,yBADyBA;YACrBA,SAASA,GAAmBA,CAACA,CAACA;QAClCA,IAAIA,WAAWA,GAAoBA,IAAIA,CAACA,WAAWA,CAACA,UAAUA,CAACA;QAC/DA,IAAIA,GAAiBA,CAACA;QACtBA,IAAIA,EAASA,EAAEA,EAASA,EAAEA,EAASA,EAAEA,EAASA,CAACA;QAC/CA,IAAIA,GAAUA,EAAEA,GAAUA,EAAEA,GAAUA,CAACA;QACvCA,IAAIA,GAAUA,EAAEA,GAAUA,EAAEA,GAAUA,CAACA;QACvCA,IAAIA,GAAUA,EAAEA,GAAUA,EAAEA,GAAUA,CAACA;QACvCA,IAAIA,GAAUA,EAAEA,GAAUA,EAAEA,GAAUA,CAACA;QACvCA,IAAIA,GAAUA,EAAEA,GAAUA,EAAEA,GAAUA,CAACA;QACvCA,IAAIA,GAAUA,EAAEA,GAAUA,EAAEA,GAAUA,EAAEA,GAAUA,CAACA;QACnDA,IAAIA,GAAUA,EAAEA,GAAUA,EAAEA,GAAUA,EAAEA,GAAUA,CAACA;QACnDA,IAAIA,GAAUA,EAAEA,GAAUA,EAAEA,GAAUA,EAAEA,GAAUA,CAACA;QACnDA,IAAIA,MAAMA,GAAwBA,IAAIA,CAACA,SAASA,CAACA,MAAMA,CAACA;QACxDA,IAAIA,IAAcA,CAACA;QACnBA,IAAIA,IAAeA,CAACA;QACpBA,IAAIA,GAAYA,CAACA;QACjBA,IAAIA,CAAQA,CAACA;QAEbA,GAAGA,CAACA,CAACA,GAAGA,CAACA,CAACA,GAAmBA,CAACA,EAAEA,CAACA,GAAGA,IAAIA,CAACA,UAAUA,EAAEA,EAAEA,CAACA,EAAEA,CAACA;YAC1DA,IAAIA,GAAGA,WAAWA,CAACA,CAACA,CAACA,CAACA;YACtBA,IAAIA,GAAGA,IAAIA,CAACA,WAAWA,CAACA;YACxBA,GAAGA,GAAGA,IAAIA,CAACA,WAAWA,CAACA;YACvBA,EAAEA,GAAGA,IAAIA,CAACA,CAACA,CAACA;YACZA,EAAEA,GAAGA,IAAIA,CAACA,CAACA,CAACA;YACZA,EAAEA,GAAGA,IAAIA,CAACA,CAACA,CAACA;YACZA,EAAEA,GAAGA,IAAIA,CAACA,CAACA,CAACA;YAEZA,GAAGA,GAAGA,CAACA,CAACA,GAAGA,GAAGA,GAACA,EAAEA,CAACA,GAACA,EAAEA,CAACA;YACtBA,GAAGA,GAAGA,CAACA,GAACA,EAAEA,CAACA;YACXA,GAAGA,GAAGA,CAACA,GAACA,EAAEA,CAACA;YACXA,GAAGA,GAAGA,CAACA,CAACA,GAAGA,GAAGA,GAACA,EAAEA,CAACA,GAACA,EAAEA,CAACA;YACtBA,GAAGA,GAAGA,CAACA,GAACA,EAAEA,CAACA;YACXA,GAAGA,GAAGA,GAAGA,GAACA,EAAEA,GAACA,EAAEA,CAACA;YAEhBA,GAAGA,GAAGA,GAAGA,GAACA,EAAEA,GAACA,EAAEA,CAACA;YAChBA,GAAGA,GAAGA,GAAGA,GAACA,EAAEA,GAACA,EAAEA,CAACA;YAChBA,GAAGA,GAAGA,GAAGA,GAACA,EAAEA,GAACA,EAAEA,CAACA;YAChBA,EAAEA,IAAIA,EAAEA,CAACA;YACTA,EAAEA,IAAIA,EAAEA,CAACA;YACTA,EAAEA,IAAIA,EAAEA,CAACA;YACTA,EAAEA,IAAIA,EAAEA,CAACA;YAETA,GAAGA,GAAGA,CAACA,CAACA,GAAGA,EAAEA,GAAGA,EAAEA,CAACA,GAAGA,EAAEA,GAAGA,EAAEA,CAACA;YAC9BA,GAAGA,GAAGA,GAAGA,GAAGA,GAAGA,CAACA;YAChBA,GAAGA,GAAGA,GAAGA,GAAGA,GAAGA,CAACA;YAChBA,GAAGA,GAAGA,GAAGA,GAAGA,GAAGA,CAACA;YAChBA,GAAGA,GAAGA,CAACA,CAACA,GAAGA,EAAEA,GAAGA,EAAEA,CAACA;YACnBA,GAAGA,GAAGA,GAAGA,GAAGA,GAAGA,CAACA;YAChBA,GAAGA,GAAGA,GAAGA,GAAGA,GAAGA,CAACA;YAChBA,GAAGA,GAAGA,GAAGA,GAAGA,GAAGA,CAACA;YAChBA,GAAGA,GAAGA,CAACA,EAAEA,GAAGA,EAAEA,GAAGA,EAAEA,GAAGA,EAAEA,CAACA;YAEzBA,AACAA,4BAD4BA;YAC5BA,GAAGA,GAAGA,MAAMA,CAACA,CAACA,CAACA,CAACA,eAAeA,CAACA;YAChCA,GAAGA,GAAGA,GAAGA,CAACA,CAACA,CAACA,CAACA;YACbA,GAAGA,GAAGA,GAAGA,CAACA,CAACA,CAACA,CAACA;YACbA,GAAGA,GAAGA,GAAGA,CAACA,CAACA,CAACA,CAACA;YACbA,GAAGA,GAAGA,GAAGA,CAACA,EAAEA,CAACA,CAACA;YACdA,GAAGA,GAAGA,GAAGA,CAACA,CAACA,CAACA,CAACA;YACbA,GAAGA,GAAGA,GAAGA,CAACA,CAACA,CAACA,CAACA;YACbA,GAAGA,GAAGA,GAAGA,CAACA,CAACA,CAACA,CAACA;YACbA,GAAGA,GAAGA,GAAGA,CAACA,EAAEA,CAACA,CAACA;YACdA,GAAGA,GAAGA,GAAGA,CAACA,CAACA,CAACA,CAACA;YACbA,GAAGA,GAAGA,GAAGA,CAACA,CAACA,CAACA,CAACA;YACbA,GAAGA,GAAGA,GAAGA,CAACA,EAAEA,CAACA,CAACA;YACdA,GAAGA,GAAGA,GAAGA,CAACA,EAAEA,CAACA,CAACA;YAEdA,IAAIA,CAACA,eAAeA,CAACA,SAASA,CAACA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,CAACA;YAC9DA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,CAACA,CAACA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,CAACA;YAClEA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,CAACA,CAACA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,CAACA;YAClEA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,CAACA,CAACA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,CAACA,CAACA,CAACA;YAC1EA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,CAACA,CAACA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,CAACA;YAClEA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,CAACA,CAACA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,CAACA;YAClEA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,CAACA,CAACA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,CAACA;YAClEA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,CAACA,CAACA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,CAACA,CAACA,CAACA;YAC1EA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,CAACA,CAACA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,CAACA;YAClEA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,CAACA,CAACA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,CAACA;YAClEA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,EAAEA,CAACA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,CAACA;YACnEA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,EAAEA,CAACA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,GAACA,GAAGA,GAAGA,GAAGA,CAACA,CAACA,CAACA;YAE3EA,SAASA,GAAGA,SAASA,GAAGA,EAAEA,CAACA;QAC5BA,CAACA;IACFA,CAACA;IAGMb,mDAAwBA,GAA/BA,UAAgCA,UAAoCA,EAAEA,iBAAqCA;QAE1Gc,IAAIA,CAACA,wBAAwBA,CAACA,iBAAiBA,CAACA,EAAEA,CAACA,GAAGA,IAAIA,CAACA;QAE3DA,AACAA,8BAD8BA;QAC9BA,EAAEA,CAACA,CAACA,CAACA,IAAIA,CAACA,cAAcA,CAACA,OAAOA,CAACA;YAChCA,MAAMA,CAACA,iBAAiBA,CAACA;QAE1BA,IAAIA,iBAAqCA,CAACA;QAE1CA,EAAEA,CAACA,CAACA,CAACA,CAACA,iBAAiBA,GAAGA,IAAIA,CAACA,mBAAmBA,CAACA,iBAAiBA,CAACA,EAAEA,CAACA,CAACA,CAACA,CAACA,CAACA;YAC3EA,AACAA,gBADgBA;YAChBA,iBAAiBA,GAAGA,IAAIA,CAACA,mBAAmBA,CAACA,iBAAiBA,CAACA,EAAEA,CAACA,GAAGA,iBAAiBA,CAACA,KAAKA,EAAEA,CAACA;YAC/FA,AACAA,oDADoDA;YACpDA,iBAAiBA,CAACA,iBAAiBA,GAAGA,KAAKA,CAACA;YAC5CA,iBAAiBA,CAACA,kBAAkBA,GAAGA,KAAKA,CAACA;YAC7CA,iBAAiBA,CAACA,aAAaA,GAAGA,KAAKA,CAACA;YACxCA,AACAA,yEADyEA;YACzEA,iBAAiBA,CAACA,gBAAgBA,CAACA,gBAAgBA,CAACA,eAAeA,EAAEA,IAAIA,CAACA,wBAAwBA,CAACA,CAACA;YACpGA,iBAAiBA,CAACA,gBAAgBA,CAACA,gBAAgBA,CAACA,gBAAgBA,EAAEA,IAAIA,CAACA,yBAAyBA,CAACA,CAACA;QACvGA,CAACA;QAEDA,MAAMA,CAACA,iBAAiBA,CAACA;IAC1BA,CAACA;IAEDd;;;;OAIGA;IACIA,2CAAgBA,GAAvBA,UAAwBA,UAAoCA,EAAEA,iBAAqCA;QAElGe,IAAIA,CAACA,wBAAwBA,CAACA,iBAAiBA,CAACA,EAAEA,CAACA,GAAGA,KAAKA,CAACA;QAE5DA,IAAIA,eAAeA,GAAiBA,iBAAiBA,CAACA,SAASA,CAACA;QAChEA,IAAIA,aAAaA,GAAiBA,iBAAiBA,CAACA,aAAaA,CAACA;QAClEA,IAAIA,cAAcA,GAAiBA,iBAAiBA,CAACA,cAAcA,CAACA;QAEpEA,IAAIA,YAAYA,GAAiBA,iBAAiBA,CAACA,YAAYA,CAACA;QAChEA,IAAIA,YAAYA,GAAiBA,iBAAiBA,CAACA,YAAYA,CAACA;QAEhEA,IAAIA,iBAAiBA,GAAGA,IAAIA,CAACA,mBAAmBA,CAACA,iBAAiBA,CAACA,EAAEA,CAACA,CAACA;QAEvEA,IAAIA,eAAeA,GAAiBA,iBAAiBA,CAACA,SAASA,CAACA;QAChEA,IAAIA,aAAaA,GAAiBA,iBAAiBA,CAACA,aAAaA,CAACA;QAClEA,IAAIA,cAAcA,GAAiBA,iBAAiBA,CAACA,cAAcA,CAACA;QAEpEA,IAAIA,KAAKA,GAAmBA,CAACA,CAACA;QAC9BA,IAAIA,CAACA,GAAmBA,CAACA,CAACA;QAC1BA,IAAIA,CAACA,CAAQA,QAADA,AAASA,CAACA;QACtBA,IAAIA,EAASA,EAAEA,EAASA,EAAEA,EAASA,CAACA;QACpCA,IAAIA,EAASA,EAAEA,EAASA,EAAEA,EAASA,CAACA;QACpCA,IAAIA,EAASA,EAAEA,EAASA,EAAEA,EAASA,CAACA;QACpCA,IAAIA,GAAGA,GAAkBA,eAAeA,CAACA,MAAMA,CAACA;QAChDA,IAAIA,MAAaA,CAACA;QAClBA,IAAIA,KAAYA,EAAEA,KAAYA,EAAEA,KAAYA,CAACA;QAC7CA,IAAIA,KAAYA,EAAEA,KAAYA,EAAEA,KAAYA,CAACA;QAC7CA,IAAIA,KAAYA,EAAEA,KAAYA,EAAEA,KAAYA,CAACA;QAC7CA,IAAIA,GAAUA,EAAEA,GAAUA,EAAEA,GAAUA,EAAEA,GAAUA,CAACA;QACnDA,IAAIA,GAAUA,EAAEA,GAAUA,EAAEA,GAAUA,EAAEA,GAAUA,CAACA;QACnDA,IAAIA,GAAUA,EAAEA,GAAUA,EAAEA,GAAUA,EAAEA,GAAUA,CAACA;QAEnDA,OAAOA,KAAKA,GAAGA,GAAGA,EAAEA,CAACA;YACpBA,KAAKA,GAAGA,eAAeA,CAACA,KAAKA,CAACA,CAACA;YAC/BA,KAAKA,GAAGA,eAAeA,CAACA,KAAKA,GAAGA,CAACA,CAACA,CAACA;YACnCA,KAAKA,GAAGA,eAAeA,CAACA,KAAKA,GAAGA,CAACA,CAACA,CAACA;YACnCA,KAAKA,GAAGA,aAAaA,CAACA,KAAKA,CAACA,CAACA;YAC7BA,KAAKA,GAAGA,aAAaA,CAACA,KAAKA,GAAGA,CAACA,CAACA,CAACA;YACjCA,KAAKA,GAAGA,aAAaA,CAACA,KAAKA,GAAGA,CAACA,CAACA,CAACA;YACjCA,KAAKA,GAAGA,cAAcA,CAACA,KAAKA,CAACA,CAACA;YAC9BA,KAAKA,GAAGA,cAAcA,CAACA,KAAKA,GAAGA,CAACA,CAACA,CAACA;YAClCA,KAAKA,GAAGA,cAAcA,CAACA,KAAKA,GAAGA,CAACA,CAACA,CAACA;YAClCA,EAAEA,GAAGA,CAACA,CAACA;YACPA,EAAEA,GAAGA,CAACA,CAACA;YACPA,EAAEA,GAAGA,CAACA,CAACA;YACPA,EAAEA,GAAGA,CAACA,CAACA;YACPA,EAAEA,GAAGA,CAACA,CAACA;YACPA,EAAEA,GAAGA,CAACA,CAACA;YACPA,EAAEA,GAAGA,CAACA,CAACA;YACPA,EAAEA,GAAGA,CAACA,CAACA;YACPA,EAAEA,GAAGA,CAACA,CAACA;YACPA,CAACA,GAAGA,CAACA,CAACA;YACNA,OAAOA,CAACA,GAAGA,IAAIA,CAACA,gBAAgBA,EAAEA,CAACA;gBAClCA,MAAMA,GAAGA,YAAYA,CAACA,CAACA,CAACA,CAACA;gBACzBA,EAAEA,CAACA,CAACA,MAAMA,GAAGA,CAACA,CAACA,CAACA,CAACA;oBAChBA,AACAA,kHADkHA;wBAC9GA,SAASA,GAAmBA,YAAYA,CAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,CAACA;oBACvDA,GAAGA,GAAGA,IAAIA,CAACA,eAAeA,CAACA,SAASA,CAACA,CAACA;oBACtCA,GAAGA,GAAGA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,CAACA,CAACA,CAACA;oBAC1CA,GAAGA,GAAGA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,CAACA,CAACA,CAACA;oBAC1CA,GAAGA,GAAGA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,CAACA,CAACA,CAACA;oBAC1CA,GAAGA,GAAGA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,CAACA,CAACA,CAACA;oBAC1CA,GAAGA,GAAGA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,CAACA,CAACA,CAACA;oBAC1CA,GAAGA,GAAGA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,CAACA,CAACA,CAACA;oBAC1CA,GAAGA,GAAGA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,CAACA,CAACA,CAACA;oBAC1CA,GAAGA,GAAGA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,CAACA,CAACA,CAACA;oBAC1CA,GAAGA,GAAGA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,CAACA,CAACA,CAACA;oBAC1CA,GAAGA,GAAGA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,EAAEA,CAACA,CAACA;oBAC3CA,GAAGA,GAAGA,IAAIA,CAACA,eAAeA,CAACA,SAASA,GAAGA,EAAEA,CAACA,CAACA;oBAC3CA,EAAEA,IAAIA,MAAMA,GAACA,CAACA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,CAACA,CAACA;oBACvDA,EAAEA,IAAIA,MAAMA,GAACA,CAACA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,CAACA,CAACA;oBACvDA,EAAEA,IAAIA,MAAMA,GAACA,CAACA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,CAACA,CAACA;oBACvDA,EAAEA,IAAIA,MAAMA,GAACA,CAACA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,GAACA,KAAKA,CAACA,CAACA;oBACjDA,EAAEA,IAAIA,MAAMA,GAACA,CAACA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,GAACA,KAAKA,CAACA,CAACA;oBACjDA,EAAEA,IAAIA,MAAMA,GAACA,CAACA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,GAACA,KAAKA,CAACA,CAACA;oBACjDA,EAAEA,IAAIA,MAAMA,GAACA,CAACA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,GAACA,KAAKA,CAACA,CAACA;oBACjDA,EAAEA,IAAIA,MAAMA,GAACA,CAACA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,GAACA,KAAKA,CAACA,CAACA;oBACjDA,EAAEA,IAAIA,MAAMA,GAACA,CAACA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,GAACA,KAAKA,GAAGA,GAAGA,GAACA,KAAKA,CAACA,CAACA;oBACjDA,EAAEA,CAACA,CAACA;gBACLA,CAACA;gBAACA,IAAIA,CAACA,CAACA;oBACPA,CAACA,IAAIA,CAACA,IAAIA,CAACA,gBAAgBA,GAAGA,CAACA,CAACA,CAACA;oBACjCA,CAACA,GAAGA,IAAIA,CAACA,gBAAgBA,CAACA;gBAC3BA,CAACA;YACFA,CAACA;YAEDA,eAAeA,CAACA,KAAKA,CAACA,GAAGA,EAAEA,CAACA;YAC5BA,eAAeA,CAACA,KAAKA,GAAGA,CAACA,CAACA,GAAGA,EAAEA,CAACA;YAChCA,eAAeA,CAACA,KAAKA,GAAGA,CAACA,CAACA,GAAGA,EAAEA,CAACA;YAChCA,aAAaA,CAACA,KAAKA,CAACA,GAAGA,EAAEA,CAACA;YAC1BA,aAAaA,CAACA,KAAKA,GAAGA,CAACA,CAACA,GAAGA,EAAEA,CAACA;YAC9BA,aAAaA,CAACA,KAAKA,GAAGA,CAACA,CAACA,GAAGA,EAAEA,CAACA;YAC9BA,cAAcA,CAACA,KAAKA,CAACA,GAAGA,EAAEA,CAACA;YAC3BA,cAAcA,CAACA,KAAKA,GAAGA,CAACA,CAACA,GAAGA,EAAEA,CAACA;YAC/BA,cAAcA,CAACA,KAAKA,GAAGA,CAACA,CAACA,GAAGA,EAAEA,CAACA;YAE/BA,KAAKA,IAAIA,CAACA,CAACA;QACZA,CAACA;QAEDA,iBAAiBA,CAACA,eAAeA,CAACA,eAAeA,CAACA,CAACA;QACnDA,iBAAiBA,CAACA,mBAAmBA,CAACA,aAAaA,CAACA,CAACA;QACrDA,iBAAiBA,CAACA,oBAAoBA,CAACA,cAAcA,CAACA,CAACA;IACxDA,CAACA;IAEDf;;;;OAIGA;IACKA,4CAAiBA,GAAzBA,UAA0BA,UAAuBA,EAAEA,UAAuBA,EAAEA,QAAiBA;QAE5FgB,IAAIA,WAAWA,GAAoBA,UAAUA,CAACA,UAAUA,CAACA;QACzDA,IAAIA,eAAyBA,CAACA;QAC9BA,IAAIA,MAAMA,GAAwBA,QAAQA,CAACA,MAAMA,CAACA;QAClDA,IAAIA,GAAGA,GAAmBA,UAAUA,CAACA,aAAaA,CAACA;QACnDA,IAAIA,UAAUA,GAAoBA,UAAUA,CAACA,UAAUA,CAACA;QACxDA,IAAIA,WAAWA,CAAQA,OAADA,AAAQA,CAACA;QAC/BA,IAAIA,KAAmBA,CAACA;QACxBA,IAAIA,UAAoBA,CAACA;QACzBA,IAAIA,IAAcA,CAACA;QACnBA,IAAIA,EAAaA,CAACA;QAClBA,IAAIA,EAAWA,CAACA;QAChBA,IAAIA,CAAUA,CAACA;QACfA,IAAIA,CAAYA,CAACA;QAEjBA,IAAIA,EAASA,EAAEA,EAASA,EAAEA,EAASA,EAAEA,EAASA,CAACA;QAC/CA,IAAIA,EAASA,EAAEA,EAASA,EAAEA,EAASA,EAAEA,EAASA,CAACA;QAC/CA,IAAIA,EAASA,EAAEA,EAASA,EAAEA,EAASA,CAACA;QAEpCA,AACAA,KADKA;QACLA,EAAEA,CAACA,CAACA,WAAWA,CAACA,MAAMA,IAAIA,GAAGA,CAACA;YAC7BA,WAAWA,CAACA,MAAMA,GAAGA,GAAGA,CAACA;QAE1BA,GAAGA,CAACA,CAACA,GAAGA,CAACA,CAACA,GAAmBA,CAACA,EAAEA,CAACA,GAAGA,GAAGA,EAAEA,EAAEA,CAACA,EAAEA,CAACA;YAC9CA,eAAeA,GAAGA,WAAWA,CAACA,CAACA,CAACA,CAACA;YAEjCA,EAAEA,CAACA,CAACA,eAAeA,IAAIA,IAAIA,CAACA;gBAC3BA,eAAeA,GAAGA,WAAWA,CAACA,CAACA,CAACA,GAAGA,IAAIA,SAASA,EAAEA,CAACA;YAEpDA,KAAKA,GAAGA,MAAMA,CAACA,CAACA,CAACA,CAACA;YAClBA,WAAWA,GAAGA,KAAKA,CAACA,WAAWA,CAACA;YAChCA,IAAIA,GAAGA,UAAUA,CAACA,CAACA,CAACA,CAACA;YAErBA,CAACA,GAAGA,eAAeA,CAACA,WAAWA,CAACA;YAChCA,CAACA,GAAGA,eAAeA,CAACA,WAAWA,CAACA;YAEhCA,EAAEA,CAACA,CAACA,WAAWA,GAAGA,CAACA,CAACA,CAACA,CAACA;gBACrBA,EAAEA,GAAGA,IAAIA,CAACA,WAAWA,CAACA;gBACtBA,EAAEA,GAAGA,IAAIA,CAACA,WAAWA,CAACA;gBACtBA,CAACA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBACXA,CAACA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBACXA,CAACA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBACXA,CAACA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBACXA,CAACA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBACXA,CAACA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBACXA,CAACA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,CAACA;YACZA,CAACA;YAACA,IAAIA,CAACA,CAACA;gBACPA,AACAA,qBADqBA;gBACrBA,UAAUA,GAAGA,WAAWA,CAACA,WAAWA,CAACA,CAACA;gBAEtCA,AACAA,eADeA;gBACfA,EAAEA,GAAGA,UAAUA,CAACA,WAAWA,CAACA;gBAC5BA,EAAEA,GAAGA,IAAIA,CAACA,WAAWA,CAACA;gBACtBA,EAAEA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBACVA,EAAEA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBACVA,EAAEA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBACVA,EAAEA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBACVA,EAAEA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBACVA,EAAEA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBACVA,EAAEA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBAEVA,EAAEA,GAAGA,CAACA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,CAACA;gBAC5BA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,CAACA;gBAC3BA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,CAACA;gBAC3BA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,CAACA;gBAE3BA,AACAA,4BAD4BA;gBAC5BA,EAAEA,GAAGA,UAAUA,CAACA,WAAWA,CAACA;gBAC5BA,CAACA,CAACA,CAACA,GAAGA,CAACA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBAC5CA,CAACA,CAACA,CAACA,GAAGA,CAACA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBAC5CA,CAACA,CAACA,CAACA,GAAGA,CAACA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBAE5CA,AACAA,4BAD4BA;gBAC5BA,EAAEA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBACVA,EAAEA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBACVA,EAAEA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBACVA,EAAEA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBACVA,EAAEA,GAAGA,IAAIA,CAACA,WAAWA,CAACA;gBACtBA,EAAEA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBACVA,EAAEA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBACVA,EAAEA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBACVA,EAAEA,GAAGA,EAAEA,CAACA,CAACA,CAACA;gBAEVA,CAACA,CAACA,CAACA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,CAACA;gBACpCA,CAACA,CAACA,CAACA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,CAACA;gBACpCA,CAACA,CAACA,CAACA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,CAACA;gBACpCA,CAACA,CAACA,CAACA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,CAACA;YACrCA,CAACA;QACFA,CAACA;IACFA,CAACA;IAEOhB,+CAAoBA,GAA5BA,UAA6BA,KAAyBA;QAErDiB,EAAEA,CAACA,CAACA,KAAKA,CAACA,IAAIA,IAAIA,mBAAmBA,CAACA,mBAAmBA,CAACA,CAACA,CAACA;YAC3DA,KAAKA,CAACA,aAAaA,CAACA,mBAAmBA,CAACA,mBAAmBA,CAACA,mBAAmBA,EAAEA,IAAIA,CAACA,6BAA6BA,CAACA,CAACA;YACrHA,AACAA,mFADmFA;YACnFA,EAAEA,CAACA,CAACA,IAAIA,CAACA,aAAaA,IAAIA,KAAKA,CAACA,cAAcA,CAACA,CAACA,CAACA;gBAChDA,IAAIA,CAACA,YAAYA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,YAAYA,CAACA,IAAIA,CAACA,qBAAqBA,CAACA,CAACA;gBACjFA,IAAIA,CAACA,aAAaA,GAAGA,IAAIA,CAACA,iBAAiBA,CAACA,IAAIA,CAACA,YAAYA,CAACA,CAACA;gBAC/DA,IAAIA,CAACA,oBAAoBA,GAA6BA,IAAIA,CAACA,aAAaA,CAACA;YAC1EA,CAACA;QACFA,CAACA;IACFA,CAACA;IAEOjB,0CAAeA,GAAvBA,UAAwBA,KAAsBA;QAE7CkB,IAAIA,WAAWA,GAA6CA,KAAKA,CAACA,MAAMA,CAACA;QAElDA,IAAIA,CAACA,mBAAmBA,CAACA,WAAWA,CAACA,EAAEA,CAAEA,CAACA,aAAaA,CAACA,WAAWA,CAACA,OAAOA,CAACA,CAACA;IACrGA,CAACA;IAEOlB,2CAAgBA,GAAxBA,UAAyBA,KAAsBA;QAE9CmB,IAAIA,WAAWA,GAA6CA,KAAKA,CAACA,MAAMA,CAACA;QACzEA,IAAIA,aAAaA,GAA6CA,IAAIA,CAACA,mBAAmBA,CAACA,WAAWA,CAACA,EAAEA,CAACA,CAACA;QAEvGA,MAAMA,CAAAA,CAACA,KAAKA,CAACA,QAAQA,CAACA,CAACA,CAACA;YACvBA,KAAKA,mBAAmBA,CAACA,OAAOA;gBAC/BA,aAAaA,CAACA,SAASA,CAACA,WAAWA,CAACA,GAAGA,CAACA,CAACA;YAC1CA,KAAKA,mBAAmBA,CAACA,iBAAiBA;gBACzCA,aAAaA,CAACA,SAASA,CAACA,WAAWA,CAACA,YAAYA,CAACA,CAACA;QACpDA,CAACA;IACFA,CAACA;IACFnB,uBAACA;AAADA,CArlBA,AAqlBCA,EArlB8B,YAAY,EAqlB1C;AAED,AAA0B,iBAAjB,gBAAgB,CAAC","file":"animators/SkeletonAnimator.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import ISubMesh\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/base/ISubMesh\");\nimport TriangleSubGeometry\t\t\t\t= require(\"awayjs-core/lib/core/base/TriangleSubGeometry\");\nimport TriangleSubMesh\t\t\t\t\t= require(\"awayjs-core/lib/core/base/TriangleSubMesh\");\nimport Quaternion\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Quaternion\");\nimport Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\nimport Camera\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Camera\");\nimport SubGeometryEvent\t\t\t\t\t= require(\"awayjs-core/lib/events/SubGeometryEvent\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport RenderableBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/RenderableBase\");\nimport TriangleSubMeshRenderable\t\t= require(\"awayjs-stagegl/lib/core/pool/TriangleSubMeshRenderable\");\nimport ContextGLProgramType\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/ContextGLProgramType\");\nimport IContextStageGL\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/IContextStageGL\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\n\nimport SkeletonAnimationSet\t\t\t\t= require(\"awayjs-renderergl/lib/animators/SkeletonAnimationSet\");\nimport JointPose\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/JointPose\");\nimport Skeleton\t\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/Skeleton\");\nimport SkeletonJoint\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/SkeletonJoint\");\nimport SkeletonPose\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/SkeletonPose\");\nimport ISkeletonAnimationState\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ISkeletonAnimationState\");\nimport IAnimationTransition\t\t\t\t= require(\"awayjs-renderergl/lib/animators/transitions/IAnimationTransition\");\nimport AnimationStateEvent\t\t\t\t= require(\"awayjs-renderergl/lib/events/AnimationStateEvent\");\n\n/**\n * Provides an interface for assigning skeleton-based animation data sets to mesh-based entity objects\n * and controlling the various available states of animation through an interative playhead that can be\n * automatically updated or manually triggered.\n */\nclass SkeletonAnimator extends AnimatorBase\n{\n\tprivate _globalMatrices:Array<number>;\n\tprivate _globalPose:SkeletonPose = new SkeletonPose();\n\tprivate _globalPropertiesDirty:boolean;\n\tprivate _numJoints:number /*uint*/;\n\tprivate _morphedSubGeometry:Object = new Object();\n\tprivate _morphedSubGeometryDirty:Object = new Object();\n\tprivate _condensedMatrices:Array<number>;\n\n\tprivate _skeleton:Skeleton;\n\tprivate _forceCPU:boolean;\n\tprivate _useCondensedIndices:boolean;\n\tprivate _jointsPerVertex:number /*uint*/;\n\tprivate _activeSkeletonState:ISkeletonAnimationState;\n\tprivate _onTransitionCompleteDelegate:(event:AnimationStateEvent) => void;\n\n\tprivate _onIndicesUpdateDelegate:(event:SubGeometryEvent) => void;\n\tprivate _onVerticesUpdateDelegate:(event:SubGeometryEvent) => void;\n\n\t/**\n\t * returns the calculated global matrices of the current skeleton pose.\n\t *\n\t * @see #globalPose\n\t */\n\tpublic get globalMatrices():Array<number>\n\t{\n\t\tif (this._globalPropertiesDirty)\n\t\t\tthis.updateGlobalProperties();\n\n\t\treturn this._globalMatrices;\n\t}\n\n\t/**\n\t * returns the current skeleton pose output from the animator.\n\t *\n\t * @see away.animators.data.SkeletonPose\n\t */\n\tpublic get globalPose():SkeletonPose\n\t{\n\t\tif (this._globalPropertiesDirty)\n\t\t\tthis.updateGlobalProperties();\n\n\t\treturn this._globalPose;\n\t}\n\n\t/**\n\t * Returns the skeleton object in use by the animator - this defines the number and heirarchy of joints used by the\n\t * skinned geoemtry to which skeleon animator is applied.\n\t */\n\tpublic get skeleton():Skeleton\n\t{\n\t\treturn this._skeleton;\n\t}\n\n\t/**\n\t * Indicates whether the skeleton animator is disabled by default for GPU rendering, something that allows the animator to perform calculation on the GPU.\n\t * Defaults to false.\n\t */\n\tpublic get forceCPU():boolean\n\t{\n\t\treturn this._forceCPU;\n\t}\n\n\t/**\n\t * Offers the option of enabling GPU accelerated animation on skeletons larger than 32 joints\n\t * by condensing the number of joint index values required per mesh. Only applicable to\n\t * skeleton animations that utilise more than one mesh object. Defaults to false.\n\t */\n\tpublic get useCondensedIndices():boolean\n\t{\n\t\treturn this._useCondensedIndices;\n\t}\n\n\tpublic set useCondensedIndices(value:boolean)\n\t{\n\t\tthis._useCondensedIndices = value;\n\t}\n\n\t/**\n\t * Creates a new <code>SkeletonAnimator</code> object.\n\t *\n\t * @param skeletonAnimationSet The animation data set containing the skeleton animations used by the animator.\n\t * @param skeleton The skeleton object used for calculating the resulting global matrices for transforming skinned mesh data.\n\t * @param forceCPU Optional value that only allows the animator to perform calculation on the CPU. Defaults to false.\n\t */\n\tconstructor(animationSet:SkeletonAnimationSet, skeleton:Skeleton, forceCPU:boolean = false)\n\t{\n\t\tsuper(animationSet);\n\n\t\tthis._skeleton = skeleton;\n\t\tthis._forceCPU = forceCPU;\n\t\tthis._jointsPerVertex = animationSet.jointsPerVertex;\n\n\t\tthis._numJoints = this._skeleton.numJoints;\n\t\tthis._globalMatrices = new Array<number>(this._numJoints*12);\n\n\t\tvar j:number /*int*/ = 0;\n\t\tfor (var i:number /*uint*/ = 0; i < this._numJoints; ++i) {\n\t\t\tthis._globalMatrices[j++] = 1;\n\t\t\tthis._globalMatrices[j++] = 0;\n\t\t\tthis._globalMatrices[j++] = 0;\n\t\t\tthis._globalMatrices[j++] = 0;\n\t\t\tthis._globalMatrices[j++] = 0;\n\t\t\tthis._globalMatrices[j++] = 1;\n\t\t\tthis._globalMatrices[j++] = 0;\n\t\t\tthis._globalMatrices[j++] = 0;\n\t\t\tthis._globalMatrices[j++] = 0;\n\t\t\tthis._globalMatrices[j++] = 0;\n\t\t\tthis._globalMatrices[j++] = 1;\n\t\t\tthis._globalMatrices[j++] = 0;\n\t\t}\n\n\t\tthis._onTransitionCompleteDelegate = (event:AnimationStateEvent) => this.onTransitionComplete(event);\n\t\tthis._onIndicesUpdateDelegate = (event:SubGeometryEvent) => this.onIndicesUpdate(event);\n\t\tthis._onVerticesUpdateDelegate = (event:SubGeometryEvent) => this.onVerticesUpdate(event);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic clone():AnimatorBase\n\t{\n\t\t/* The cast to SkeletonAnimationSet should never fail, as _animationSet can only be set\n\t\t through the constructor, which will only accept a SkeletonAnimationSet. */\n\t\treturn new SkeletonAnimator(<SkeletonAnimationSet> this._pAnimationSet, this._skeleton, this._forceCPU);\n\t}\n\n\t/**\n\t * Plays an animation state registered with the given name in the animation data set.\n\t *\n\t * @param name The data set name of the animation state to be played.\n\t * @param transition An optional transition object that determines how the animator will transition from the currently active animation state.\n\t * @param offset An option offset time (in milliseconds) that resets the state's internal clock to the absolute time of the animator plus the offset value. Required for non-looping animation states.\n\t */\n\tpublic play(name:string, transition:IAnimationTransition = null, offset:number = NaN)\n\t{\n\t\tif (this._pActiveAnimationName == name)\n\t\t\treturn;\n\n\t\tthis._pActiveAnimationName = name;\n\n\t\tif (!this._pAnimationSet.hasAnimation(name))\n\t\t\tthrow new Error(\"Animation root node \" + name + \" not found!\");\n\n\t\tif (transition && this._pActiveNode) {\n\t\t\t//setup the transition\n\t\t\tthis._pActiveNode = transition.getAnimationNode(this, this._pActiveNode, this._pAnimationSet.getAnimation(name), this._pAbsoluteTime);\n\t\t\tthis._pActiveNode.addEventListener(AnimationStateEvent.TRANSITION_COMPLETE, this._onTransitionCompleteDelegate);\n\t\t} else\n\t\t\tthis._pActiveNode = this._pAnimationSet.getAnimation(name);\n\n\t\tthis._pActiveState = this.getAnimationState(this._pActiveNode);\n\n\t\tif (this.updatePosition) {\n\t\t\t//update straight away to reset position deltas\n\t\t\tthis._pActiveState.update(this._pAbsoluteTime);\n\t\t\tthis._pActiveState.positionDelta;\n\t\t}\n\n\t\tthis._activeSkeletonState = <ISkeletonAnimationState> this._pActiveState;\n\n\t\tthis.start();\n\n\t\t//apply a time offset if specified\n\t\tif (!isNaN(offset))\n\t\t\tthis.reset(name, offset);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic setRenderState(shaderObject:ShaderObjectBase, renderable:RenderableBase, stage:Stage, camera:Camera, vertexConstantOffset:number /*int*/, vertexStreamOffset:number /*int*/)\n\t{\n\t\t// do on request of globalProperties\n\t\tif (this._globalPropertiesDirty)\n\t\t\tthis.updateGlobalProperties();\n\n\t\tvar subGeometry:TriangleSubGeometry = <TriangleSubGeometry> (<TriangleSubMesh> (<TriangleSubMeshRenderable> renderable).subMesh).subGeometry;\n\n\t\tsubGeometry.useCondensedIndices = this._useCondensedIndices;\n\n\t\tif (this._useCondensedIndices) {\n\t\t\t// using a condensed data set\n\t\t\tthis.updateCondensedMatrices(subGeometry.condensedIndexLookUp, subGeometry.numCondensedJoints);\n\t\t\t(<IContextStageGL> stage.context).setProgramConstantsFromArray(ContextGLProgramType.VERTEX, vertexConstantOffset, this._condensedMatrices, subGeometry.numCondensedJoints*3);\n\t\t} else {\n\t\t\tif (this._pAnimationSet.usesCPU) {\n\t\t\t\tif (this._morphedSubGeometryDirty[subGeometry.id])\n\t\t\t\t\tthis.morphSubGeometry(<TriangleSubMeshRenderable> renderable, subGeometry);\n\n\t\t\t\treturn\n\t\t\t}\n\t\t\t(<IContextStageGL> stage.context).setProgramConstantsFromArray(ContextGLProgramType.VERTEX, vertexConstantOffset, this._globalMatrices, this._numJoints*3);\n\t\t}\n\n\t\t(<IContextStageGL> stage.context).activateBuffer(vertexStreamOffset, renderable.getVertexData(TriangleSubGeometry.JOINT_INDEX_DATA), renderable.getVertexOffset(TriangleSubGeometry.JOINT_INDEX_DATA), renderable.JOINT_INDEX_FORMAT);\n\t\t(<IContextStageGL> stage.context).activateBuffer(vertexStreamOffset + 1, renderable.getVertexData(TriangleSubGeometry.JOINT_WEIGHT_DATA), renderable.getVertexOffset(TriangleSubGeometry.JOINT_WEIGHT_DATA), renderable.JOINT_WEIGHT_FORMAT);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic testGPUCompatibility(shaderObject:ShaderObjectBase)\n\t{\n\t\tif (!this._useCondensedIndices && (this._forceCPU || this._jointsPerVertex > 4 || shaderObject.numUsedVertexConstants + this._numJoints*3 > 128))\n\t\t\tthis._pAnimationSet.cancelGPUCompatibility();\n\t}\n\n\t/**\n\t * Applies the calculated time delta to the active animation state node or state transition object.\n\t */\n\tpublic _pUpdateDeltaTime(dt:number)\n\t{\n\t\tsuper._pUpdateDeltaTime(dt);\n\n\t\t//invalidate pose matrices\n\t\tthis._globalPropertiesDirty = true;\n\n\t\t//trigger geometry invalidation if using CPU animation\n\t\tif (this._pAnimationSet.usesCPU)\n\t\t\tfor (var key in this._morphedSubGeometryDirty)\n\t\t\t\tthis._morphedSubGeometryDirty[key] = true;\n\t}\n\n\tprivate updateCondensedMatrices(condensedIndexLookUp:Array<number> /*uint*/, numJoints:number /*uint*/)\n\t{\n\t\tvar i:number /*uint*/ = 0, j:number /*uint*/ = 0;\n\t\tvar len:number /*uint*/;\n\t\tvar srcIndex:number /*uint*/;\n\n\t\tthis._condensedMatrices = new Array<number>();\n\n\t\tdo {\n\t\t\tsrcIndex = condensedIndexLookUp[i]*4;\n\t\t\tlen = srcIndex + 12;\n\t\t\t// copy into condensed\n\t\t\twhile (srcIndex < len)\n\t\t\t\tthis._condensedMatrices[j++] = this._globalMatrices[srcIndex++];\n\t\t} while (++i < numJoints);\n\t}\n\n\tprivate updateGlobalProperties()\n\t{\n\t\tthis._globalPropertiesDirty = false;\n\n\t\t//get global pose\n\t\tthis.localToGlobalPose(this._activeSkeletonState.getSkeletonPose(this._skeleton), this._globalPose, this._skeleton);\n\n\t\t// convert pose to matrix\n\t\tvar mtxOffset:number /*uint*/ = 0;\n\t\tvar globalPoses:Array<JointPose> = this._globalPose.jointPoses;\n\t\tvar raw:Array<number>;\n\t\tvar ox:number, oy:number, oz:number, ow:number;\n\t\tvar xy2:number, xz2:number, xw2:number;\n\t\tvar yz2:number, yw2:number, zw2:number;\n\t\tvar n11:number, n12:number, n13:number;\n\t\tvar n21:number, n22:number, n23:number;\n\t\tvar n31:number, n32:number, n33:number;\n\t\tvar m11:number, m12:number, m13:number, m14:number;\n\t\tvar m21:number, m22:number, m23:number, m24:number;\n\t\tvar m31:number, m32:number, m33:number, m34:number;\n\t\tvar joints:Array<SkeletonJoint> = this._skeleton.joints;\n\t\tvar pose:JointPose;\n\t\tvar quat:Quaternion;\n\t\tvar vec:Vector3D;\n\t\tvar t:number;\n\n\t\tfor (var i:number /*uint*/ = 0; i < this._numJoints; ++i) {\n\t\t\tpose = globalPoses[i];\n\t\t\tquat = pose.orientation;\n\t\t\tvec = pose.translation;\n\t\t\tox = quat.x;\n\t\t\toy = quat.y;\n\t\t\toz = quat.z;\n\t\t\tow = quat.w;\n\n\t\t\txy2 = (t = 2.0*ox)*oy;\n\t\t\txz2 = t*oz;\n\t\t\txw2 = t*ow;\n\t\t\tyz2 = (t = 2.0*oy)*oz;\n\t\t\tyw2 = t*ow;\n\t\t\tzw2 = 2.0*oz*ow;\n\n\t\t\tyz2 = 2.0*oy*oz;\n\t\t\tyw2 = 2.0*oy*ow;\n\t\t\tzw2 = 2.0*oz*ow;\n\t\t\tox *= ox;\n\t\t\toy *= oy;\n\t\t\toz *= oz;\n\t\t\tow *= ow;\n\n\t\t\tn11 = (t = ox - oy) - oz + ow;\n\t\t\tn12 = xy2 - zw2;\n\t\t\tn13 = xz2 + yw2;\n\t\t\tn21 = xy2 + zw2;\n\t\t\tn22 = -t - oz + ow;\n\t\t\tn23 = yz2 - xw2;\n\t\t\tn31 = xz2 - yw2;\n\t\t\tn32 = yz2 + xw2;\n\t\t\tn33 = -ox - oy + oz + ow;\n\n\t\t\t// prepend inverse bind pose\n\t\t\traw = joints[i].inverseBindPose;\n\t\t\tm11 = raw[0];\n\t\t\tm12 = raw[4];\n\t\t\tm13 = raw[8];\n\t\t\tm14 = raw[12];\n\t\t\tm21 = raw[1];\n\t\t\tm22 = raw[5];\n\t\t\tm23 = raw[9];\n\t\t\tm24 = raw[13];\n\t\t\tm31 = raw[2];\n\t\t\tm32 = raw[6];\n\t\t\tm33 = raw[10];\n\t\t\tm34 = raw[14];\n\n\t\t\tthis._globalMatrices[mtxOffset] = n11*m11 + n12*m21 + n13*m31;\n\t\t\tthis._globalMatrices[mtxOffset + 1] = n11*m12 + n12*m22 + n13*m32;\n\t\t\tthis._globalMatrices[mtxOffset + 2] = n11*m13 + n12*m23 + n13*m33;\n\t\t\tthis._globalMatrices[mtxOffset + 3] = n11*m14 + n12*m24 + n13*m34 + vec.x;\n\t\t\tthis._globalMatrices[mtxOffset + 4] = n21*m11 + n22*m21 + n23*m31;\n\t\t\tthis._globalMatrices[mtxOffset + 5] = n21*m12 + n22*m22 + n23*m32;\n\t\t\tthis._globalMatrices[mtxOffset + 6] = n21*m13 + n22*m23 + n23*m33;\n\t\t\tthis._globalMatrices[mtxOffset + 7] = n21*m14 + n22*m24 + n23*m34 + vec.y;\n\t\t\tthis._globalMatrices[mtxOffset + 8] = n31*m11 + n32*m21 + n33*m31;\n\t\t\tthis._globalMatrices[mtxOffset + 9] = n31*m12 + n32*m22 + n33*m32;\n\t\t\tthis._globalMatrices[mtxOffset + 10] = n31*m13 + n32*m23 + n33*m33;\n\t\t\tthis._globalMatrices[mtxOffset + 11] = n31*m14 + n32*m24 + n33*m34 + vec.z;\n\n\t\t\tmtxOffset = mtxOffset + 12;\n\t\t}\n\t}\n\n\n\tpublic getRenderableSubGeometry(renderable:TriangleSubMeshRenderable, sourceSubGeometry:TriangleSubGeometry):TriangleSubGeometry\n\t{\n\t\tthis._morphedSubGeometryDirty[sourceSubGeometry.id] = true;\n\n\t\t//early out for GPU animations\n\t\tif (!this._pAnimationSet.usesCPU)\n\t\t\treturn sourceSubGeometry;\n\n\t\tvar targetSubGeometry:TriangleSubGeometry;\n\n\t\tif (!(targetSubGeometry = this._morphedSubGeometry[sourceSubGeometry.id])) {\n\t\t\t//not yet stored\n\t\t\ttargetSubGeometry = this._morphedSubGeometry[sourceSubGeometry.id] = sourceSubGeometry.clone();\n\t\t\t//turn off auto calculations on the morphed geometry\n\t\t\ttargetSubGeometry.autoDeriveNormals = false;\n\t\t\ttargetSubGeometry.autoDeriveTangents = false;\n\t\t\ttargetSubGeometry.autoDeriveUVs = false;\n\t\t\t//add event listeners for any changes in UV values on the source geometry\n\t\t\tsourceSubGeometry.addEventListener(SubGeometryEvent.INDICES_UPDATED, this._onIndicesUpdateDelegate);\n\t\t\tsourceSubGeometry.addEventListener(SubGeometryEvent.VERTICES_UPDATED, this._onVerticesUpdateDelegate);\n\t\t}\n\n\t\treturn targetSubGeometry;\n\t}\n\n\t/**\n\t * If the animation can't be performed on GPU, transform vertices manually\n\t * @param subGeom The subgeometry containing the weights and joint index data per vertex.\n\t * @param pass The material pass for which we need to transform the vertices\n\t */\n\tpublic morphSubGeometry(renderable:TriangleSubMeshRenderable, sourceSubGeometry:TriangleSubGeometry)\n\t{\n\t\tthis._morphedSubGeometryDirty[sourceSubGeometry.id] = false;\n\n\t\tvar sourcePositions:Array<number> = sourceSubGeometry.positions;\n\t\tvar sourceNormals:Array<number> = sourceSubGeometry.vertexNormals;\n\t\tvar sourceTangents:Array<number> = sourceSubGeometry.vertexTangents;\n\n\t\tvar jointIndices:Array<number> = sourceSubGeometry.jointIndices;\n\t\tvar jointWeights:Array<number> = sourceSubGeometry.jointWeights;\n\n\t\tvar targetSubGeometry = this._morphedSubGeometry[sourceSubGeometry.id];\n\n\t\tvar targetPositions:Array<number> = targetSubGeometry.positions;\n\t\tvar targetNormals:Array<number> = targetSubGeometry.vertexNormals;\n\t\tvar targetTangents:Array<number> = targetSubGeometry.vertexTangents;\n\n\t\tvar index:number /*uint*/ = 0;\n\t\tvar j:number /*uint*/ = 0;\n\t\tvar k:number /*uint*/;\n\t\tvar vx:number, vy:number, vz:number;\n\t\tvar nx:number, ny:number, nz:number;\n\t\tvar tx:number, ty:number, tz:number;\n\t\tvar len:number /*int*/ = sourcePositions.length;\n\t\tvar weight:number;\n\t\tvar vertX:number, vertY:number, vertZ:number;\n\t\tvar normX:number, normY:number, normZ:number;\n\t\tvar tangX:number, tangY:number, tangZ:number;\n\t\tvar m11:number, m12:number, m13:number, m14:number;\n\t\tvar m21:number, m22:number, m23:number, m24:number;\n\t\tvar m31:number, m32:number, m33:number, m34:number;\n\n\t\twhile (index < len) {\n\t\t\tvertX = sourcePositions[index];\n\t\t\tvertY = sourcePositions[index + 1];\n\t\t\tvertZ = sourcePositions[index + 2];\n\t\t\tnormX = sourceNormals[index];\n\t\t\tnormY = sourceNormals[index + 1];\n\t\t\tnormZ = sourceNormals[index + 2];\n\t\t\ttangX = sourceTangents[index];\n\t\t\ttangY = sourceTangents[index + 1];\n\t\t\ttangZ = sourceTangents[index + 2];\n\t\t\tvx = 0;\n\t\t\tvy = 0;\n\t\t\tvz = 0;\n\t\t\tnx = 0;\n\t\t\tny = 0;\n\t\t\tnz = 0;\n\t\t\ttx = 0;\n\t\t\tty = 0;\n\t\t\ttz = 0;\n\t\t\tk = 0;\n\t\t\twhile (k < this._jointsPerVertex) {\n\t\t\t\tweight = jointWeights[j];\n\t\t\t\tif (weight > 0) {\n\t\t\t\t\t// implicit /3*12 (/3 because indices are multiplied by 3 for gpu matrix access, *12 because it's the matrix size)\n\t\t\t\t\tvar mtxOffset:number /*uint*/ = jointIndices[j++] << 2;\n\t\t\t\t\tm11 = this._globalMatrices[mtxOffset];\n\t\t\t\t\tm12 = this._globalMatrices[mtxOffset + 1];\n\t\t\t\t\tm13 = this._globalMatrices[mtxOffset + 2];\n\t\t\t\t\tm14 = this._globalMatrices[mtxOffset + 3];\n\t\t\t\t\tm21 = this._globalMatrices[mtxOffset + 4];\n\t\t\t\t\tm22 = this._globalMatrices[mtxOffset + 5];\n\t\t\t\t\tm23 = this._globalMatrices[mtxOffset + 6];\n\t\t\t\t\tm24 = this._globalMatrices[mtxOffset + 7];\n\t\t\t\t\tm31 = this._globalMatrices[mtxOffset + 8];\n\t\t\t\t\tm32 = this._globalMatrices[mtxOffset + 9];\n\t\t\t\t\tm33 = this._globalMatrices[mtxOffset + 10];\n\t\t\t\t\tm34 = this._globalMatrices[mtxOffset + 11];\n\t\t\t\t\tvx += weight*(m11*vertX + m12*vertY + m13*vertZ + m14);\n\t\t\t\t\tvy += weight*(m21*vertX + m22*vertY + m23*vertZ + m24);\n\t\t\t\t\tvz += weight*(m31*vertX + m32*vertY + m33*vertZ + m34);\n\t\t\t\t\tnx += weight*(m11*normX + m12*normY + m13*normZ);\n\t\t\t\t\tny += weight*(m21*normX + m22*normY + m23*normZ);\n\t\t\t\t\tnz += weight*(m31*normX + m32*normY + m33*normZ);\n\t\t\t\t\ttx += weight*(m11*tangX + m12*tangY + m13*tangZ);\n\t\t\t\t\tty += weight*(m21*tangX + m22*tangY + m23*tangZ);\n\t\t\t\t\ttz += weight*(m31*tangX + m32*tangY + m33*tangZ);\n\t\t\t\t\t++k;\n\t\t\t\t} else {\n\t\t\t\t\tj += (this._jointsPerVertex - k);\n\t\t\t\t\tk = this._jointsPerVertex;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\ttargetPositions[index] = vx;\n\t\t\ttargetPositions[index + 1] = vy;\n\t\t\ttargetPositions[index + 2] = vz;\n\t\t\ttargetNormals[index] = nx;\n\t\t\ttargetNormals[index + 1] = ny;\n\t\t\ttargetNormals[index + 2] = nz;\n\t\t\ttargetTangents[index] = tx;\n\t\t\ttargetTangents[index + 1] = ty;\n\t\t\ttargetTangents[index + 2] = tz;\n\n\t\t\tindex += 3;\n\t\t}\n\n\t\ttargetSubGeometry.updatePositions(targetPositions);\n\t\ttargetSubGeometry.updateVertexNormals(targetNormals);\n\t\ttargetSubGeometry.updateVertexTangents(targetTangents);\n\t}\n\n\t/**\n\t * Converts a local hierarchical skeleton pose to a global pose\n\t * @param targetPose The SkeletonPose object that will contain the global pose.\n\t * @param skeleton The skeleton containing the joints, and as such, the hierarchical data to transform to global poses.\n\t */\n\tprivate localToGlobalPose(sourcePose:SkeletonPose, targetPose:SkeletonPose, skeleton:Skeleton)\n\t{\n\t\tvar globalPoses:Array<JointPose> = targetPose.jointPoses;\n\t\tvar globalJointPose:JointPose;\n\t\tvar joints:Array<SkeletonJoint> = skeleton.joints;\n\t\tvar len:number /*uint*/ = sourcePose.numJointPoses;\n\t\tvar jointPoses:Array<JointPose> = sourcePose.jointPoses;\n\t\tvar parentIndex:number /*int*/;\n\t\tvar joint:SkeletonJoint;\n\t\tvar parentPose:JointPose;\n\t\tvar pose:JointPose;\n\t\tvar or:Quaternion;\n\t\tvar tr:Vector3D;\n\t\tvar t:Vector3D;\n\t\tvar q:Quaternion;\n\n\t\tvar x1:number, y1:number, z1:number, w1:number;\n\t\tvar x2:number, y2:number, z2:number, w2:number;\n\t\tvar x3:number, y3:number, z3:number;\n\n\t\t// :s\n\t\tif (globalPoses.length != len)\n\t\t\tglobalPoses.length = len;\n\n\t\tfor (var i:number /*uint*/ = 0; i < len; ++i) {\n\t\t\tglobalJointPose = globalPoses[i];\n\n\t\t\tif (globalJointPose == null)\n\t\t\t\tglobalJointPose = globalPoses[i] = new JointPose();\n\n\t\t\tjoint = joints[i];\n\t\t\tparentIndex = joint.parentIndex;\n\t\t\tpose = jointPoses[i];\n\n\t\t\tq = globalJointPose.orientation;\n\t\t\tt = globalJointPose.translation;\n\n\t\t\tif (parentIndex < 0) {\n\t\t\t\ttr = pose.translation;\n\t\t\t\tor = pose.orientation;\n\t\t\t\tq.x = or.x;\n\t\t\t\tq.y = or.y;\n\t\t\t\tq.z = or.z;\n\t\t\t\tq.w = or.w;\n\t\t\t\tt.x = tr.x;\n\t\t\t\tt.y = tr.y;\n\t\t\t\tt.z = tr.z;\n\t\t\t} else {\n\t\t\t\t// append parent pose\n\t\t\t\tparentPose = globalPoses[parentIndex];\n\n\t\t\t\t// rotate point\n\t\t\t\tor = parentPose.orientation;\n\t\t\t\ttr = pose.translation;\n\t\t\t\tx2 = or.x;\n\t\t\t\ty2 = or.y;\n\t\t\t\tz2 = or.z;\n\t\t\t\tw2 = or.w;\n\t\t\t\tx3 = tr.x;\n\t\t\t\ty3 = tr.y;\n\t\t\t\tz3 = tr.z;\n\n\t\t\t\tw1 = -x2*x3 - y2*y3 - z2*z3;\n\t\t\t\tx1 = w2*x3 + y2*z3 - z2*y3;\n\t\t\t\ty1 = w2*y3 - x2*z3 + z2*x3;\n\t\t\t\tz1 = w2*z3 + x2*y3 - y2*x3;\n\n\t\t\t\t// append parent translation\n\t\t\t\ttr = parentPose.translation;\n\t\t\t\tt.x = -w1*x2 + x1*w2 - y1*z2 + z1*y2 + tr.x;\n\t\t\t\tt.y = -w1*y2 + x1*z2 + y1*w2 - z1*x2 + tr.y;\n\t\t\t\tt.z = -w1*z2 - x1*y2 + y1*x2 + z1*w2 + tr.z;\n\n\t\t\t\t// append parent orientation\n\t\t\t\tx1 = or.x;\n\t\t\t\ty1 = or.y;\n\t\t\t\tz1 = or.z;\n\t\t\t\tw1 = or.w;\n\t\t\t\tor = pose.orientation;\n\t\t\t\tx2 = or.x;\n\t\t\t\ty2 = or.y;\n\t\t\t\tz2 = or.z;\n\t\t\t\tw2 = or.w;\n\n\t\t\t\tq.w = w1*w2 - x1*x2 - y1*y2 - z1*z2;\n\t\t\t\tq.x = w1*x2 + x1*w2 + y1*z2 - z1*y2;\n\t\t\t\tq.y = w1*y2 - x1*z2 + y1*w2 + z1*x2;\n\t\t\t\tq.z = w1*z2 + x1*y2 - y1*x2 + z1*w2;\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate onTransitionComplete(event:AnimationStateEvent)\n\t{\n\t\tif (event.type == AnimationStateEvent.TRANSITION_COMPLETE) {\n\t\t\tevent.animationNode.removeEventListener(AnimationStateEvent.TRANSITION_COMPLETE, this._onTransitionCompleteDelegate);\n\t\t\t//if this is the current active state transition, revert control to the active node\n\t\t\tif (this._pActiveState == event.animationState) {\n\t\t\t\tthis._pActiveNode = this._pAnimationSet.getAnimation(this._pActiveAnimationName);\n\t\t\t\tthis._pActiveState = this.getAnimationState(this._pActiveNode);\n\t\t\t\tthis._activeSkeletonState = <ISkeletonAnimationState> this._pActiveState;\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate onIndicesUpdate(event:SubGeometryEvent)\n\t{\n\t\tvar subGeometry:TriangleSubGeometry = <TriangleSubGeometry> event.target;\n\n\t\t(<TriangleSubGeometry> this._morphedSubGeometry[subGeometry.id]).updateIndices(subGeometry.indices);\n\t}\n\n\tprivate onVerticesUpdate(event:SubGeometryEvent)\n\t{\n\t\tvar subGeometry:TriangleSubGeometry = <TriangleSubGeometry> event.target;\n\t\tvar morphGeometry:TriangleSubGeometry = <TriangleSubGeometry> this._morphedSubGeometry[subGeometry.id];\n\n\t\tswitch(event.dataType) {\n\t\t\tcase TriangleSubGeometry.UV_DATA:\n\t\t\t\tmorphGeometry.updateUVs(subGeometry.uvs);\n\t\t\tcase TriangleSubGeometry.SECONDARY_UV_DATA:\n\t\t\t\tmorphGeometry.updateUVs(subGeometry.secondaryUVs);\n\t\t}\n\t}\n}\n\nexport = SkeletonAnimator;"]}
\ No newline at end of file
diff --git a/lib/animators/SkeletonAnimator.ts b/lib/animators/SkeletonAnimator.ts
new file mode 100644
index 000000000..00e827b8d
--- /dev/null
+++ b/lib/animators/SkeletonAnimator.ts
@@ -0,0 +1,630 @@
+import ISubMesh = require("awayjs-core/lib/core/base/ISubMesh");
+import TriangleSubGeometry = require("awayjs-core/lib/core/base/TriangleSubGeometry");
+import TriangleSubMesh = require("awayjs-core/lib/core/base/TriangleSubMesh");
+import Quaternion = require("awayjs-core/lib/core/geom/Quaternion");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import Camera = require("awayjs-core/lib/entities/Camera");
+import SubGeometryEvent = require("awayjs-core/lib/events/SubGeometryEvent");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import TriangleSubMeshRenderable = require("awayjs-stagegl/lib/core/pool/TriangleSubMeshRenderable");
+import ContextGLProgramType = require("awayjs-stagegl/lib/core/stagegl/ContextGLProgramType");
+import IContextStageGL = require("awayjs-stagegl/lib/core/stagegl/IContextStageGL");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+
+import SkeletonAnimationSet = require("awayjs-renderergl/lib/animators/SkeletonAnimationSet");
+import JointPose = require("awayjs-renderergl/lib/animators/data/JointPose");
+import Skeleton = require("awayjs-renderergl/lib/animators/data/Skeleton");
+import SkeletonJoint = require("awayjs-renderergl/lib/animators/data/SkeletonJoint");
+import SkeletonPose = require("awayjs-renderergl/lib/animators/data/SkeletonPose");
+import ISkeletonAnimationState = require("awayjs-renderergl/lib/animators/states/ISkeletonAnimationState");
+import IAnimationTransition = require("awayjs-renderergl/lib/animators/transitions/IAnimationTransition");
+import AnimationStateEvent = require("awayjs-renderergl/lib/events/AnimationStateEvent");
+
+/**
+ * Provides an interface for assigning skeleton-based animation data sets to mesh-based entity objects
+ * and controlling the various available states of animation through an interative playhead that can be
+ * automatically updated or manually triggered.
+ */
+class SkeletonAnimator extends AnimatorBase
+{
+ private _globalMatrices:Array;
+ private _globalPose:SkeletonPose = new SkeletonPose();
+ private _globalPropertiesDirty:boolean;
+ private _numJoints:number /*uint*/;
+ private _morphedSubGeometry:Object = new Object();
+ private _morphedSubGeometryDirty:Object = new Object();
+ private _condensedMatrices:Array;
+
+ private _skeleton:Skeleton;
+ private _forceCPU:boolean;
+ private _useCondensedIndices:boolean;
+ private _jointsPerVertex:number /*uint*/;
+ private _activeSkeletonState:ISkeletonAnimationState;
+ private _onTransitionCompleteDelegate:(event:AnimationStateEvent) => void;
+
+ private _onIndicesUpdateDelegate:(event:SubGeometryEvent) => void;
+ private _onVerticesUpdateDelegate:(event:SubGeometryEvent) => void;
+
+ /**
+ * returns the calculated global matrices of the current skeleton pose.
+ *
+ * @see #globalPose
+ */
+ public get globalMatrices():Array
+ {
+ if (this._globalPropertiesDirty)
+ this.updateGlobalProperties();
+
+ return this._globalMatrices;
+ }
+
+ /**
+ * returns the current skeleton pose output from the animator.
+ *
+ * @see away.animators.data.SkeletonPose
+ */
+ public get globalPose():SkeletonPose
+ {
+ if (this._globalPropertiesDirty)
+ this.updateGlobalProperties();
+
+ return this._globalPose;
+ }
+
+ /**
+ * Returns the skeleton object in use by the animator - this defines the number and heirarchy of joints used by the
+ * skinned geoemtry to which skeleon animator is applied.
+ */
+ public get skeleton():Skeleton
+ {
+ return this._skeleton;
+ }
+
+ /**
+ * Indicates whether the skeleton animator is disabled by default for GPU rendering, something that allows the animator to perform calculation on the GPU.
+ * Defaults to false.
+ */
+ public get forceCPU():boolean
+ {
+ return this._forceCPU;
+ }
+
+ /**
+ * Offers the option of enabling GPU accelerated animation on skeletons larger than 32 joints
+ * by condensing the number of joint index values required per mesh. Only applicable to
+ * skeleton animations that utilise more than one mesh object. Defaults to false.
+ */
+ public get useCondensedIndices():boolean
+ {
+ return this._useCondensedIndices;
+ }
+
+ public set useCondensedIndices(value:boolean)
+ {
+ this._useCondensedIndices = value;
+ }
+
+ /**
+ * Creates a new SkeletonAnimator
object.
+ *
+ * @param skeletonAnimationSet The animation data set containing the skeleton animations used by the animator.
+ * @param skeleton The skeleton object used for calculating the resulting global matrices for transforming skinned mesh data.
+ * @param forceCPU Optional value that only allows the animator to perform calculation on the CPU. Defaults to false.
+ */
+ constructor(animationSet:SkeletonAnimationSet, skeleton:Skeleton, forceCPU:boolean = false)
+ {
+ super(animationSet);
+
+ this._skeleton = skeleton;
+ this._forceCPU = forceCPU;
+ this._jointsPerVertex = animationSet.jointsPerVertex;
+
+ this._numJoints = this._skeleton.numJoints;
+ this._globalMatrices = new Array(this._numJoints*12);
+
+ var j:number /*int*/ = 0;
+ for (var i:number /*uint*/ = 0; i < this._numJoints; ++i) {
+ this._globalMatrices[j++] = 1;
+ this._globalMatrices[j++] = 0;
+ this._globalMatrices[j++] = 0;
+ this._globalMatrices[j++] = 0;
+ this._globalMatrices[j++] = 0;
+ this._globalMatrices[j++] = 1;
+ this._globalMatrices[j++] = 0;
+ this._globalMatrices[j++] = 0;
+ this._globalMatrices[j++] = 0;
+ this._globalMatrices[j++] = 0;
+ this._globalMatrices[j++] = 1;
+ this._globalMatrices[j++] = 0;
+ }
+
+ this._onTransitionCompleteDelegate = (event:AnimationStateEvent) => this.onTransitionComplete(event);
+ this._onIndicesUpdateDelegate = (event:SubGeometryEvent) => this.onIndicesUpdate(event);
+ this._onVerticesUpdateDelegate = (event:SubGeometryEvent) => this.onVerticesUpdate(event);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public clone():AnimatorBase
+ {
+ /* The cast to SkeletonAnimationSet should never fail, as _animationSet can only be set
+ through the constructor, which will only accept a SkeletonAnimationSet. */
+ return new SkeletonAnimator( this._pAnimationSet, this._skeleton, this._forceCPU);
+ }
+
+ /**
+ * Plays an animation state registered with the given name in the animation data set.
+ *
+ * @param name The data set name of the animation state to be played.
+ * @param transition An optional transition object that determines how the animator will transition from the currently active animation state.
+ * @param offset An option offset time (in milliseconds) that resets the state's internal clock to the absolute time of the animator plus the offset value. Required for non-looping animation states.
+ */
+ public play(name:string, transition:IAnimationTransition = null, offset:number = NaN)
+ {
+ if (this._pActiveAnimationName == name)
+ return;
+
+ this._pActiveAnimationName = name;
+
+ if (!this._pAnimationSet.hasAnimation(name))
+ throw new Error("Animation root node " + name + " not found!");
+
+ if (transition && this._pActiveNode) {
+ //setup the transition
+ this._pActiveNode = transition.getAnimationNode(this, this._pActiveNode, this._pAnimationSet.getAnimation(name), this._pAbsoluteTime);
+ this._pActiveNode.addEventListener(AnimationStateEvent.TRANSITION_COMPLETE, this._onTransitionCompleteDelegate);
+ } else
+ this._pActiveNode = this._pAnimationSet.getAnimation(name);
+
+ this._pActiveState = this.getAnimationState(this._pActiveNode);
+
+ if (this.updatePosition) {
+ //update straight away to reset position deltas
+ this._pActiveState.update(this._pAbsoluteTime);
+ this._pActiveState.positionDelta;
+ }
+
+ this._activeSkeletonState = this._pActiveState;
+
+ this.start();
+
+ //apply a time offset if specified
+ if (!isNaN(offset))
+ this.reset(name, offset);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public setRenderState(shaderObject:ShaderObjectBase, renderable:RenderableBase, stage:Stage, camera:Camera, vertexConstantOffset:number /*int*/, vertexStreamOffset:number /*int*/)
+ {
+ // do on request of globalProperties
+ if (this._globalPropertiesDirty)
+ this.updateGlobalProperties();
+
+ var subGeometry:TriangleSubGeometry = ( ( renderable).subMesh).subGeometry;
+
+ subGeometry.useCondensedIndices = this._useCondensedIndices;
+
+ if (this._useCondensedIndices) {
+ // using a condensed data set
+ this.updateCondensedMatrices(subGeometry.condensedIndexLookUp, subGeometry.numCondensedJoints);
+ ( stage.context).setProgramConstantsFromArray(ContextGLProgramType.VERTEX, vertexConstantOffset, this._condensedMatrices, subGeometry.numCondensedJoints*3);
+ } else {
+ if (this._pAnimationSet.usesCPU) {
+ if (this._morphedSubGeometryDirty[subGeometry.id])
+ this.morphSubGeometry( renderable, subGeometry);
+
+ return
+ }
+ ( stage.context).setProgramConstantsFromArray(ContextGLProgramType.VERTEX, vertexConstantOffset, this._globalMatrices, this._numJoints*3);
+ }
+
+ ( stage.context).activateBuffer(vertexStreamOffset, renderable.getVertexData(TriangleSubGeometry.JOINT_INDEX_DATA), renderable.getVertexOffset(TriangleSubGeometry.JOINT_INDEX_DATA), renderable.JOINT_INDEX_FORMAT);
+ ( stage.context).activateBuffer(vertexStreamOffset + 1, renderable.getVertexData(TriangleSubGeometry.JOINT_WEIGHT_DATA), renderable.getVertexOffset(TriangleSubGeometry.JOINT_WEIGHT_DATA), renderable.JOINT_WEIGHT_FORMAT);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public testGPUCompatibility(shaderObject:ShaderObjectBase)
+ {
+ if (!this._useCondensedIndices && (this._forceCPU || this._jointsPerVertex > 4 || shaderObject.numUsedVertexConstants + this._numJoints*3 > 128))
+ this._pAnimationSet.cancelGPUCompatibility();
+ }
+
+ /**
+ * Applies the calculated time delta to the active animation state node or state transition object.
+ */
+ public _pUpdateDeltaTime(dt:number)
+ {
+ super._pUpdateDeltaTime(dt);
+
+ //invalidate pose matrices
+ this._globalPropertiesDirty = true;
+
+ //trigger geometry invalidation if using CPU animation
+ if (this._pAnimationSet.usesCPU)
+ for (var key in this._morphedSubGeometryDirty)
+ this._morphedSubGeometryDirty[key] = true;
+ }
+
+ private updateCondensedMatrices(condensedIndexLookUp:Array /*uint*/, numJoints:number /*uint*/)
+ {
+ var i:number /*uint*/ = 0, j:number /*uint*/ = 0;
+ var len:number /*uint*/;
+ var srcIndex:number /*uint*/;
+
+ this._condensedMatrices = new Array();
+
+ do {
+ srcIndex = condensedIndexLookUp[i]*4;
+ len = srcIndex + 12;
+ // copy into condensed
+ while (srcIndex < len)
+ this._condensedMatrices[j++] = this._globalMatrices[srcIndex++];
+ } while (++i < numJoints);
+ }
+
+ private updateGlobalProperties()
+ {
+ this._globalPropertiesDirty = false;
+
+ //get global pose
+ this.localToGlobalPose(this._activeSkeletonState.getSkeletonPose(this._skeleton), this._globalPose, this._skeleton);
+
+ // convert pose to matrix
+ var mtxOffset:number /*uint*/ = 0;
+ var globalPoses:Array = this._globalPose.jointPoses;
+ var raw:Array;
+ var ox:number, oy:number, oz:number, ow:number;
+ var xy2:number, xz2:number, xw2:number;
+ var yz2:number, yw2:number, zw2:number;
+ var n11:number, n12:number, n13:number;
+ var n21:number, n22:number, n23:number;
+ var n31:number, n32:number, n33:number;
+ var m11:number, m12:number, m13:number, m14:number;
+ var m21:number, m22:number, m23:number, m24:number;
+ var m31:number, m32:number, m33:number, m34:number;
+ var joints:Array = this._skeleton.joints;
+ var pose:JointPose;
+ var quat:Quaternion;
+ var vec:Vector3D;
+ var t:number;
+
+ for (var i:number /*uint*/ = 0; i < this._numJoints; ++i) {
+ pose = globalPoses[i];
+ quat = pose.orientation;
+ vec = pose.translation;
+ ox = quat.x;
+ oy = quat.y;
+ oz = quat.z;
+ ow = quat.w;
+
+ xy2 = (t = 2.0*ox)*oy;
+ xz2 = t*oz;
+ xw2 = t*ow;
+ yz2 = (t = 2.0*oy)*oz;
+ yw2 = t*ow;
+ zw2 = 2.0*oz*ow;
+
+ yz2 = 2.0*oy*oz;
+ yw2 = 2.0*oy*ow;
+ zw2 = 2.0*oz*ow;
+ ox *= ox;
+ oy *= oy;
+ oz *= oz;
+ ow *= ow;
+
+ n11 = (t = ox - oy) - oz + ow;
+ n12 = xy2 - zw2;
+ n13 = xz2 + yw2;
+ n21 = xy2 + zw2;
+ n22 = -t - oz + ow;
+ n23 = yz2 - xw2;
+ n31 = xz2 - yw2;
+ n32 = yz2 + xw2;
+ n33 = -ox - oy + oz + ow;
+
+ // prepend inverse bind pose
+ raw = joints[i].inverseBindPose;
+ m11 = raw[0];
+ m12 = raw[4];
+ m13 = raw[8];
+ m14 = raw[12];
+ m21 = raw[1];
+ m22 = raw[5];
+ m23 = raw[9];
+ m24 = raw[13];
+ m31 = raw[2];
+ m32 = raw[6];
+ m33 = raw[10];
+ m34 = raw[14];
+
+ this._globalMatrices[mtxOffset] = n11*m11 + n12*m21 + n13*m31;
+ this._globalMatrices[mtxOffset + 1] = n11*m12 + n12*m22 + n13*m32;
+ this._globalMatrices[mtxOffset + 2] = n11*m13 + n12*m23 + n13*m33;
+ this._globalMatrices[mtxOffset + 3] = n11*m14 + n12*m24 + n13*m34 + vec.x;
+ this._globalMatrices[mtxOffset + 4] = n21*m11 + n22*m21 + n23*m31;
+ this._globalMatrices[mtxOffset + 5] = n21*m12 + n22*m22 + n23*m32;
+ this._globalMatrices[mtxOffset + 6] = n21*m13 + n22*m23 + n23*m33;
+ this._globalMatrices[mtxOffset + 7] = n21*m14 + n22*m24 + n23*m34 + vec.y;
+ this._globalMatrices[mtxOffset + 8] = n31*m11 + n32*m21 + n33*m31;
+ this._globalMatrices[mtxOffset + 9] = n31*m12 + n32*m22 + n33*m32;
+ this._globalMatrices[mtxOffset + 10] = n31*m13 + n32*m23 + n33*m33;
+ this._globalMatrices[mtxOffset + 11] = n31*m14 + n32*m24 + n33*m34 + vec.z;
+
+ mtxOffset = mtxOffset + 12;
+ }
+ }
+
+
+ public getRenderableSubGeometry(renderable:TriangleSubMeshRenderable, sourceSubGeometry:TriangleSubGeometry):TriangleSubGeometry
+ {
+ this._morphedSubGeometryDirty[sourceSubGeometry.id] = true;
+
+ //early out for GPU animations
+ if (!this._pAnimationSet.usesCPU)
+ return sourceSubGeometry;
+
+ var targetSubGeometry:TriangleSubGeometry;
+
+ if (!(targetSubGeometry = this._morphedSubGeometry[sourceSubGeometry.id])) {
+ //not yet stored
+ targetSubGeometry = this._morphedSubGeometry[sourceSubGeometry.id] = sourceSubGeometry.clone();
+ //turn off auto calculations on the morphed geometry
+ targetSubGeometry.autoDeriveNormals = false;
+ targetSubGeometry.autoDeriveTangents = false;
+ targetSubGeometry.autoDeriveUVs = false;
+ //add event listeners for any changes in UV values on the source geometry
+ sourceSubGeometry.addEventListener(SubGeometryEvent.INDICES_UPDATED, this._onIndicesUpdateDelegate);
+ sourceSubGeometry.addEventListener(SubGeometryEvent.VERTICES_UPDATED, this._onVerticesUpdateDelegate);
+ }
+
+ return targetSubGeometry;
+ }
+
+ /**
+ * If the animation can't be performed on GPU, transform vertices manually
+ * @param subGeom The subgeometry containing the weights and joint index data per vertex.
+ * @param pass The material pass for which we need to transform the vertices
+ */
+ public morphSubGeometry(renderable:TriangleSubMeshRenderable, sourceSubGeometry:TriangleSubGeometry)
+ {
+ this._morphedSubGeometryDirty[sourceSubGeometry.id] = false;
+
+ var sourcePositions:Array = sourceSubGeometry.positions;
+ var sourceNormals:Array = sourceSubGeometry.vertexNormals;
+ var sourceTangents:Array = sourceSubGeometry.vertexTangents;
+
+ var jointIndices:Array = sourceSubGeometry.jointIndices;
+ var jointWeights:Array = sourceSubGeometry.jointWeights;
+
+ var targetSubGeometry = this._morphedSubGeometry[sourceSubGeometry.id];
+
+ var targetPositions:Array = targetSubGeometry.positions;
+ var targetNormals:Array = targetSubGeometry.vertexNormals;
+ var targetTangents:Array = targetSubGeometry.vertexTangents;
+
+ var index:number /*uint*/ = 0;
+ var j:number /*uint*/ = 0;
+ var k:number /*uint*/;
+ var vx:number, vy:number, vz:number;
+ var nx:number, ny:number, nz:number;
+ var tx:number, ty:number, tz:number;
+ var len:number /*int*/ = sourcePositions.length;
+ var weight:number;
+ var vertX:number, vertY:number, vertZ:number;
+ var normX:number, normY:number, normZ:number;
+ var tangX:number, tangY:number, tangZ:number;
+ var m11:number, m12:number, m13:number, m14:number;
+ var m21:number, m22:number, m23:number, m24:number;
+ var m31:number, m32:number, m33:number, m34:number;
+
+ while (index < len) {
+ vertX = sourcePositions[index];
+ vertY = sourcePositions[index + 1];
+ vertZ = sourcePositions[index + 2];
+ normX = sourceNormals[index];
+ normY = sourceNormals[index + 1];
+ normZ = sourceNormals[index + 2];
+ tangX = sourceTangents[index];
+ tangY = sourceTangents[index + 1];
+ tangZ = sourceTangents[index + 2];
+ vx = 0;
+ vy = 0;
+ vz = 0;
+ nx = 0;
+ ny = 0;
+ nz = 0;
+ tx = 0;
+ ty = 0;
+ tz = 0;
+ k = 0;
+ while (k < this._jointsPerVertex) {
+ weight = jointWeights[j];
+ if (weight > 0) {
+ // implicit /3*12 (/3 because indices are multiplied by 3 for gpu matrix access, *12 because it's the matrix size)
+ var mtxOffset:number /*uint*/ = jointIndices[j++] << 2;
+ m11 = this._globalMatrices[mtxOffset];
+ m12 = this._globalMatrices[mtxOffset + 1];
+ m13 = this._globalMatrices[mtxOffset + 2];
+ m14 = this._globalMatrices[mtxOffset + 3];
+ m21 = this._globalMatrices[mtxOffset + 4];
+ m22 = this._globalMatrices[mtxOffset + 5];
+ m23 = this._globalMatrices[mtxOffset + 6];
+ m24 = this._globalMatrices[mtxOffset + 7];
+ m31 = this._globalMatrices[mtxOffset + 8];
+ m32 = this._globalMatrices[mtxOffset + 9];
+ m33 = this._globalMatrices[mtxOffset + 10];
+ m34 = this._globalMatrices[mtxOffset + 11];
+ vx += weight*(m11*vertX + m12*vertY + m13*vertZ + m14);
+ vy += weight*(m21*vertX + m22*vertY + m23*vertZ + m24);
+ vz += weight*(m31*vertX + m32*vertY + m33*vertZ + m34);
+ nx += weight*(m11*normX + m12*normY + m13*normZ);
+ ny += weight*(m21*normX + m22*normY + m23*normZ);
+ nz += weight*(m31*normX + m32*normY + m33*normZ);
+ tx += weight*(m11*tangX + m12*tangY + m13*tangZ);
+ ty += weight*(m21*tangX + m22*tangY + m23*tangZ);
+ tz += weight*(m31*tangX + m32*tangY + m33*tangZ);
+ ++k;
+ } else {
+ j += (this._jointsPerVertex - k);
+ k = this._jointsPerVertex;
+ }
+ }
+
+ targetPositions[index] = vx;
+ targetPositions[index + 1] = vy;
+ targetPositions[index + 2] = vz;
+ targetNormals[index] = nx;
+ targetNormals[index + 1] = ny;
+ targetNormals[index + 2] = nz;
+ targetTangents[index] = tx;
+ targetTangents[index + 1] = ty;
+ targetTangents[index + 2] = tz;
+
+ index += 3;
+ }
+
+ targetSubGeometry.updatePositions(targetPositions);
+ targetSubGeometry.updateVertexNormals(targetNormals);
+ targetSubGeometry.updateVertexTangents(targetTangents);
+ }
+
+ /**
+ * Converts a local hierarchical skeleton pose to a global pose
+ * @param targetPose The SkeletonPose object that will contain the global pose.
+ * @param skeleton The skeleton containing the joints, and as such, the hierarchical data to transform to global poses.
+ */
+ private localToGlobalPose(sourcePose:SkeletonPose, targetPose:SkeletonPose, skeleton:Skeleton)
+ {
+ var globalPoses:Array = targetPose.jointPoses;
+ var globalJointPose:JointPose;
+ var joints:Array = skeleton.joints;
+ var len:number /*uint*/ = sourcePose.numJointPoses;
+ var jointPoses:Array = sourcePose.jointPoses;
+ var parentIndex:number /*int*/;
+ var joint:SkeletonJoint;
+ var parentPose:JointPose;
+ var pose:JointPose;
+ var or:Quaternion;
+ var tr:Vector3D;
+ var t:Vector3D;
+ var q:Quaternion;
+
+ var x1:number, y1:number, z1:number, w1:number;
+ var x2:number, y2:number, z2:number, w2:number;
+ var x3:number, y3:number, z3:number;
+
+ // :s
+ if (globalPoses.length != len)
+ globalPoses.length = len;
+
+ for (var i:number /*uint*/ = 0; i < len; ++i) {
+ globalJointPose = globalPoses[i];
+
+ if (globalJointPose == null)
+ globalJointPose = globalPoses[i] = new JointPose();
+
+ joint = joints[i];
+ parentIndex = joint.parentIndex;
+ pose = jointPoses[i];
+
+ q = globalJointPose.orientation;
+ t = globalJointPose.translation;
+
+ if (parentIndex < 0) {
+ tr = pose.translation;
+ or = pose.orientation;
+ q.x = or.x;
+ q.y = or.y;
+ q.z = or.z;
+ q.w = or.w;
+ t.x = tr.x;
+ t.y = tr.y;
+ t.z = tr.z;
+ } else {
+ // append parent pose
+ parentPose = globalPoses[parentIndex];
+
+ // rotate point
+ or = parentPose.orientation;
+ tr = pose.translation;
+ x2 = or.x;
+ y2 = or.y;
+ z2 = or.z;
+ w2 = or.w;
+ x3 = tr.x;
+ y3 = tr.y;
+ z3 = tr.z;
+
+ w1 = -x2*x3 - y2*y3 - z2*z3;
+ x1 = w2*x3 + y2*z3 - z2*y3;
+ y1 = w2*y3 - x2*z3 + z2*x3;
+ z1 = w2*z3 + x2*y3 - y2*x3;
+
+ // append parent translation
+ tr = parentPose.translation;
+ t.x = -w1*x2 + x1*w2 - y1*z2 + z1*y2 + tr.x;
+ t.y = -w1*y2 + x1*z2 + y1*w2 - z1*x2 + tr.y;
+ t.z = -w1*z2 - x1*y2 + y1*x2 + z1*w2 + tr.z;
+
+ // append parent orientation
+ x1 = or.x;
+ y1 = or.y;
+ z1 = or.z;
+ w1 = or.w;
+ or = pose.orientation;
+ x2 = or.x;
+ y2 = or.y;
+ z2 = or.z;
+ w2 = or.w;
+
+ q.w = w1*w2 - x1*x2 - y1*y2 - z1*z2;
+ q.x = w1*x2 + x1*w2 + y1*z2 - z1*y2;
+ q.y = w1*y2 - x1*z2 + y1*w2 + z1*x2;
+ q.z = w1*z2 + x1*y2 - y1*x2 + z1*w2;
+ }
+ }
+ }
+
+ private onTransitionComplete(event:AnimationStateEvent)
+ {
+ if (event.type == AnimationStateEvent.TRANSITION_COMPLETE) {
+ event.animationNode.removeEventListener(AnimationStateEvent.TRANSITION_COMPLETE, this._onTransitionCompleteDelegate);
+ //if this is the current active state transition, revert control to the active node
+ if (this._pActiveState == event.animationState) {
+ this._pActiveNode = this._pAnimationSet.getAnimation(this._pActiveAnimationName);
+ this._pActiveState = this.getAnimationState(this._pActiveNode);
+ this._activeSkeletonState = this._pActiveState;
+ }
+ }
+ }
+
+ private onIndicesUpdate(event:SubGeometryEvent)
+ {
+ var subGeometry:TriangleSubGeometry = event.target;
+
+ ( this._morphedSubGeometry[subGeometry.id]).updateIndices(subGeometry.indices);
+ }
+
+ private onVerticesUpdate(event:SubGeometryEvent)
+ {
+ var subGeometry:TriangleSubGeometry = event.target;
+ var morphGeometry:TriangleSubGeometry = this._morphedSubGeometry[subGeometry.id];
+
+ switch(event.dataType) {
+ case TriangleSubGeometry.UV_DATA:
+ morphGeometry.updateUVs(subGeometry.uvs);
+ case TriangleSubGeometry.SECONDARY_UV_DATA:
+ morphGeometry.updateUVs(subGeometry.secondaryUVs);
+ }
+ }
+}
+
+export = SkeletonAnimator;
\ No newline at end of file
diff --git a/lib/animators/VertexAnimationSet.js b/lib/animators/VertexAnimationSet.js
new file mode 100755
index 000000000..9b4d340c6
--- /dev/null
+++ b/lib/animators/VertexAnimationSet.js
@@ -0,0 +1,164 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var AnimationSetBase = require("awayjs-stagegl/lib/animators/AnimationSetBase");
+var VertexAnimationMode = require("awayjs-renderergl/lib/animators/data/VertexAnimationMode");
+/**
+ * The animation data set used by vertex-based animators, containing vertex animation state data.
+ *
+ * @see VertexAnimator
+ */
+var VertexAnimationSet = (function (_super) {
+ __extends(VertexAnimationSet, _super);
+ /**
+ * Returns whether or not normal data is used in last set GPU pass of the vertex shader.
+ */
+ // public get useNormals():boolean
+ // {
+ // return this._uploadNormals;
+ // }
+ /**
+ * Creates a new VertexAnimationSet
object.
+ *
+ * @param numPoses The number of poses made available at once to the GPU animation code.
+ * @param blendMode Optional value for setting the animation mode of the vertex animator object.
+ *
+ * @see away3d.animators.data.VertexAnimationMode
+ */
+ function VertexAnimationSet(numPoses, blendMode) {
+ if (numPoses === void 0) { numPoses = 2; }
+ if (blendMode === void 0) { blendMode = "absolute"; }
+ _super.call(this);
+ this._numPoses = numPoses;
+ this._blendMode = blendMode;
+ }
+ Object.defineProperty(VertexAnimationSet.prototype, "numPoses", {
+ /**
+ * Returns the number of poses made available at once to the GPU animation code.
+ */
+ get: function () {
+ return this._numPoses;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(VertexAnimationSet.prototype, "blendMode", {
+ /**
+ * Returns the active blend mode of the vertex animator object.
+ */
+ get: function () {
+ return this._blendMode;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ VertexAnimationSet.prototype.getAGALVertexCode = function (shaderObject) {
+ if (this._blendMode == VertexAnimationMode.ABSOLUTE)
+ return this.getAbsoluteAGALCode(shaderObject);
+ else
+ return this.getAdditiveAGALCode(shaderObject);
+ };
+ /**
+ * @inheritDoc
+ */
+ VertexAnimationSet.prototype.activate = function (shaderObject, stage) {
+ // var uID:number = pass._iUniqueId;
+ // this._uploadNormals = this._useNormals[uID];
+ // this._uploadTangents = this._useTangents[uID];
+ };
+ /**
+ * @inheritDoc
+ */
+ VertexAnimationSet.prototype.deactivate = function (shaderObject, stage) {
+ // var uID:number = pass._iUniqueId;
+ // var index:number /*uint*/ = this._streamIndices[uID];
+ // var context:IContextStageGL = stage.context;
+ // context.setVertexBufferAt(index, null);
+ // if (this._uploadNormals)
+ // context.setVertexBufferAt(index + 1, null);
+ // if (this._uploadTangents)
+ // context.setVertexBufferAt(index + 2, null);
+ };
+ /**
+ * @inheritDoc
+ */
+ VertexAnimationSet.prototype.getAGALFragmentCode = function (shaderObject, shadedTarget) {
+ return "";
+ };
+ /**
+ * @inheritDoc
+ */
+ VertexAnimationSet.prototype.getAGALUVCode = function (shaderObject) {
+ return "mov " + shaderObject.uvTarget + "," + shaderObject.uvSource + "\n";
+ };
+ /**
+ * @inheritDoc
+ */
+ VertexAnimationSet.prototype.doneAGALCode = function (shaderObject) {
+ };
+ /**
+ * Generates the vertex AGAL code for absolute blending.
+ */
+ VertexAnimationSet.prototype.getAbsoluteAGALCode = function (shaderObject) {
+ var code = "";
+ var temp1 = this._pFindTempReg(shaderObject.animationTargetRegisters);
+ var temp2 = this._pFindTempReg(shaderObject.animationTargetRegisters, temp1);
+ var regs = new Array("x", "y", "z", "w");
+ var len = shaderObject.animatableAttributes.length;
+ var constantReg = "vc" + shaderObject.numUsedVertexConstants;
+ if (len > 2)
+ len = 2;
+ var streamIndex = shaderObject.numUsedStreams;
+ for (var i = 0; i < len; ++i) {
+ code += "mul " + temp1 + ", " + shaderObject.animatableAttributes[i] + ", " + constantReg + "." + regs[0] + "\n";
+ for (var j = 1; j < this._numPoses; ++j) {
+ code += "mul " + temp2 + ", va" + streamIndex + ", " + constantReg + "." + regs[j] + "\n";
+ if (j < this._numPoses - 1)
+ code += "add " + temp1 + ", " + temp1 + ", " + temp2 + "\n";
+ ++streamIndex;
+ }
+ code += "add " + shaderObject.animationTargetRegisters[i] + ", " + temp1 + ", " + temp2 + "\n";
+ }
+ // add code for bitangents if tangents are used
+ if (shaderObject.tangentDependencies > 0 || shaderObject.outputsNormals) {
+ code += "dp3 " + temp1 + ".x, " + shaderObject.animatableAttributes[2] + ", " + shaderObject.animationTargetRegisters[1] + "\n" + "mul " + temp1 + ", " + shaderObject.animationTargetRegisters[1] + ", " + temp1 + ".x\n" + "sub " + shaderObject.animationTargetRegisters[2] + ", " + shaderObject.animationTargetRegisters[2] + ", " + temp1 + "\n";
+ }
+ return code;
+ };
+ /**
+ * Generates the vertex AGAL code for additive blending.
+ */
+ VertexAnimationSet.prototype.getAdditiveAGALCode = function (shaderObject) {
+ var code = "";
+ var len = shaderObject.animatableAttributes.length;
+ var regs = ["x", "y", "z", "w"];
+ var temp1 = this._pFindTempReg(shaderObject.animationTargetRegisters);
+ var k /*uint*/;
+ var streamIndex = shaderObject.numUsedStreams;
+ if (len > 2)
+ len = 2;
+ code += "mov " + shaderObject.animationTargetRegisters[0] + ", " + shaderObject.animatableAttributes[0] + "\n";
+ if (shaderObject.normalDependencies > 0)
+ code += "mov " + shaderObject.animationTargetRegisters[1] + ", " + shaderObject.animatableAttributes[1] + "\n";
+ for (var i = 0; i < len; ++i) {
+ for (var j = 0; j < this._numPoses; ++j) {
+ code += "mul " + temp1 + ", va" + (streamIndex + k) + ", vc" + shaderObject.numUsedVertexConstants + "." + regs[j] + "\n" + "add " + shaderObject.animationTargetRegisters[i] + ", " + shaderObject.animationTargetRegisters[i] + ", " + temp1 + "\n";
+ k++;
+ }
+ }
+ if (shaderObject.tangentDependencies > 0 || shaderObject.outputsNormals) {
+ code += "dp3 " + temp1 + ".x, " + shaderObject.animatableAttributes[2] + ", " + shaderObject.animationTargetRegisters[1] + "\n" + "mul " + temp1 + ", " + shaderObject.animationTargetRegisters[1] + ", " + temp1 + ".x\n" + "sub " + shaderObject.animationTargetRegisters[2] + ", " + shaderObject.animatableAttributes[2] + ", " + temp1 + "\n";
+ }
+ return code;
+ };
+ return VertexAnimationSet;
+})(AnimationSetBase);
+module.exports = VertexAnimationSet;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/vertexanimationset.ts"],"names":["VertexAnimationSet","VertexAnimationSet.constructor","VertexAnimationSet.numPoses","VertexAnimationSet.blendMode","VertexAnimationSet.getAGALVertexCode","VertexAnimationSet.activate","VertexAnimationSet.deactivate","VertexAnimationSet.getAGALFragmentCode","VertexAnimationSet.getAGALUVCode","VertexAnimationSet.doneAGALCode","VertexAnimationSet.getAbsoluteAGALCode","VertexAnimationSet.getAdditiveAGALCode"],"mappings":"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","file":"animators/VertexAnimationSet.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import IAnimationSet\t\t\t\t\t= require(\"awayjs-core/lib/animators/IAnimationSet\");\n\nimport AnimationSetBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimationSetBase\");\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\n\nimport VertexAnimationMode\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/VertexAnimationMode\");\n\n/**\n * The animation data set used by vertex-based animators, containing vertex animation state data.\n *\n * @see VertexAnimator\n */\nclass VertexAnimationSet extends AnimationSetBase implements IAnimationSet\n{\n\tprivate _numPoses:number /*uint*/;\n\tprivate _blendMode:string;\n\n\t/**\n\t * Returns the number of poses made available at once to the GPU animation code.\n\t */\n\tpublic get numPoses():number /*uint*/\n\t{\n\t\treturn this._numPoses;\n\t}\n\n\t/**\n\t * Returns the active blend mode of the vertex animator object.\n\t */\n\tpublic get blendMode():string\n\t{\n\t\treturn this._blendMode;\n\t}\n\n\t/**\n\t * Returns whether or not normal data is used in last set GPU pass of the vertex shader.\n\t */\n//\t\tpublic get useNormals():boolean\n//\t\t{\n//\t\t\treturn this._uploadNormals;\n//\t\t}\n\n\t/**\n\t * Creates a new <code>VertexAnimationSet</code> object.\n\t *\n\t * @param numPoses The number of poses made available at once to the GPU animation code.\n\t * @param blendMode Optional value for setting the animation mode of the vertex animator object.\n\t *\n\t * @see away3d.animators.data.VertexAnimationMode\n\t */\n\tconstructor(numPoses:number /*uint*/ = 2, blendMode:string = \"absolute\")\n\t{\n\t\tsuper();\n\t\tthis._numPoses = numPoses;\n\t\tthis._blendMode = blendMode;\n\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALVertexCode(shaderObject:ShaderObjectBase):string\n\t{\n\t\tif (this._blendMode == VertexAnimationMode.ABSOLUTE)\n\t\t\treturn this.getAbsoluteAGALCode(shaderObject);\n\t\telse\n\t\t\treturn this.getAdditiveAGALCode(shaderObject);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic activate(shaderObject:ShaderObjectBase, stage:Stage)\n\t{\n//\t\t\tvar uID:number = pass._iUniqueId;\n//\t\t\tthis._uploadNormals = <boolean> this._useNormals[uID];\n//\t\t\tthis._uploadTangents = <boolean> this._useTangents[uID];\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic deactivate(shaderObject:ShaderObjectBase, stage:Stage)\n\t{\n//\t\t\tvar uID:number = pass._iUniqueId;\n//\t\t\tvar index:number /*uint*/ = this._streamIndices[uID];\n//\t\t\tvar context:IContextStageGL = <IContextStageGL> stage.context;\n//\t\t\tcontext.setVertexBufferAt(index, null);\n//\t\t\tif (this._uploadNormals)\n//\t\t\t\tcontext.setVertexBufferAt(index + 1, null);\n//\t\t\tif (this._uploadTangents)\n//\t\t\t\tcontext.setVertexBufferAt(index + 2, null);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALFragmentCode(shaderObject:ShaderObjectBase, shadedTarget:string):string\n\t{\n\t\treturn \"\";\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALUVCode(shaderObject:ShaderObjectBase):string\n\t{\n\t\treturn \"mov \" + shaderObject.uvTarget + \",\" + shaderObject.uvSource + \"\\n\";\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic doneAGALCode(shaderObject:ShaderObjectBase)\n\t{\n\n\t}\n\n\t/**\n\t * Generates the vertex AGAL code for absolute blending.\n\t */\n\tprivate getAbsoluteAGALCode(shaderObject:ShaderObjectBase):string\n\t{\n\t\tvar code:string = \"\";\n\t\tvar temp1:string = this._pFindTempReg(shaderObject.animationTargetRegisters);\n\t\tvar temp2:string = this._pFindTempReg(shaderObject.animationTargetRegisters, temp1);\n\t\tvar regs:Array<string> = new Array<string>(\"x\", \"y\", \"z\", \"w\");\n\t\tvar len:number /*uint*/ = shaderObject.animatableAttributes.length;\n\t\tvar constantReg:string = \"vc\" + shaderObject.numUsedVertexConstants;\n\n\t\tif (len > 2)\n\t\t\tlen = 2;\n\t\tvar streamIndex:number /*uint*/ = shaderObject.numUsedStreams;\n\n\t\tfor (var i:number /*uint*/ = 0; i < len; ++i) {\n\t\t\tcode += \"mul \" + temp1 + \", \" + shaderObject.animatableAttributes[i] + \", \" + constantReg + \".\" + regs[0] + \"\\n\";\n\n\t\t\tfor (var j:number /*uint*/ = 1; j < this._numPoses; ++j) {\n\t\t\t\tcode += \"mul \" + temp2 + \", va\" + streamIndex + \", \" + constantReg + \".\" + regs[j] + \"\\n\";\n\n\t\t\t\tif (j < this._numPoses - 1)\n\t\t\t\t\tcode += \"add \" + temp1 + \", \" + temp1 + \", \" + temp2 + \"\\n\";\n\n\t\t\t\t++streamIndex;\n\t\t\t}\n\n\t\t\tcode += \"add \" + shaderObject.animationTargetRegisters[i] + \", \" + temp1 + \", \" + temp2 + \"\\n\";\n\t\t}\n\n\t\t// add code for bitangents if tangents are used\n\t\tif (shaderObject.tangentDependencies > 0 || shaderObject.outputsNormals) {\n\t\t\tcode += \"dp3 \" + temp1 + \".x, \" + shaderObject.animatableAttributes[2] + \", \" + shaderObject.animationTargetRegisters[1] + \"\\n\" +\n\t\t\t\t\"mul \" + temp1 + \", \" + shaderObject.animationTargetRegisters[1] + \", \" + temp1 + \".x\\n\" +\n\t\t\t\t\"sub \" + shaderObject.animationTargetRegisters[2] + \", \" + shaderObject.animationTargetRegisters[2] + \", \" + temp1 + \"\\n\";\n\t\t}\n\t\treturn code;\n\t}\n\n\t/**\n\t * Generates the vertex AGAL code for additive blending.\n\t */\n\tprivate getAdditiveAGALCode(shaderObject:ShaderObjectBase):string\n\t{\n\t\tvar code:string = \"\";\n\t\tvar len:number /*uint*/ = shaderObject.animatableAttributes.length;\n\t\tvar regs:Array<string> = [\"x\", \"y\", \"z\", \"w\"];\n\t\tvar temp1:string = this._pFindTempReg(shaderObject.animationTargetRegisters);\n\t\tvar k:number /*uint*/;\n\n\t\tvar streamIndex:number /*uint*/ = shaderObject.numUsedStreams;\n\n\t\tif (len > 2)\n\t\t\tlen = 2;\n\n\t\tcode += \"mov  \" + shaderObject.animationTargetRegisters[0] + \", \" + shaderObject.animatableAttributes[0] + \"\\n\";\n\t\tif (shaderObject.normalDependencies > 0)\n\t\t\tcode += \"mov \" + shaderObject.animationTargetRegisters[1] + \", \" + shaderObject.animatableAttributes[1] + \"\\n\";\n\n\t\tfor (var i:number /*uint*/ = 0; i < len; ++i) {\n\t\t\tfor (var j:number /*uint*/ = 0; j < this._numPoses; ++j) {\n\t\t\t\tcode += \"mul \" + temp1 + \", va\" + (streamIndex + k) + \", vc\" + shaderObject.numUsedVertexConstants + \".\" + regs[j] + \"\\n\" +\n\t\t\t\t\t\"add \" + shaderObject.animationTargetRegisters[i] + \", \" + shaderObject.animationTargetRegisters[i] + \", \" + temp1 + \"\\n\";\n\t\t\t\tk++;\n\t\t\t}\n\t\t}\n\n\t\tif (shaderObject.tangentDependencies > 0 || shaderObject.outputsNormals) {\n\t\t\tcode += \"dp3 \" + temp1 + \".x, \" + shaderObject.animatableAttributes[2] + \", \" + shaderObject.animationTargetRegisters[1] + \"\\n\" +\n\t\t\t\t\"mul \" + temp1 + \", \" + shaderObject.animationTargetRegisters[1] + \", \" + temp1 + \".x\\n\" +\n\t\t\t\t\"sub \" + shaderObject.animationTargetRegisters[2] + \", \" + shaderObject.animatableAttributes[2] + \", \" + temp1 + \"\\n\";\n\t\t}\n\n\t\treturn code;\n\t}\n}\n\nexport = VertexAnimationSet;"]}
\ No newline at end of file
diff --git a/lib/animators/VertexAnimationSet.ts b/lib/animators/VertexAnimationSet.ts
new file mode 100644
index 000000000..ed8d8385c
--- /dev/null
+++ b/lib/animators/VertexAnimationSet.ts
@@ -0,0 +1,197 @@
+import IAnimationSet = require("awayjs-core/lib/animators/IAnimationSet");
+
+import AnimationSetBase = require("awayjs-stagegl/lib/animators/AnimationSetBase");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+
+import VertexAnimationMode = require("awayjs-renderergl/lib/animators/data/VertexAnimationMode");
+
+/**
+ * The animation data set used by vertex-based animators, containing vertex animation state data.
+ *
+ * @see VertexAnimator
+ */
+class VertexAnimationSet extends AnimationSetBase implements IAnimationSet
+{
+ private _numPoses:number /*uint*/;
+ private _blendMode:string;
+
+ /**
+ * Returns the number of poses made available at once to the GPU animation code.
+ */
+ public get numPoses():number /*uint*/
+ {
+ return this._numPoses;
+ }
+
+ /**
+ * Returns the active blend mode of the vertex animator object.
+ */
+ public get blendMode():string
+ {
+ return this._blendMode;
+ }
+
+ /**
+ * Returns whether or not normal data is used in last set GPU pass of the vertex shader.
+ */
+// public get useNormals():boolean
+// {
+// return this._uploadNormals;
+// }
+
+ /**
+ * Creates a new VertexAnimationSet
object.
+ *
+ * @param numPoses The number of poses made available at once to the GPU animation code.
+ * @param blendMode Optional value for setting the animation mode of the vertex animator object.
+ *
+ * @see away3d.animators.data.VertexAnimationMode
+ */
+ constructor(numPoses:number /*uint*/ = 2, blendMode:string = "absolute")
+ {
+ super();
+ this._numPoses = numPoses;
+ this._blendMode = blendMode;
+
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALVertexCode(shaderObject:ShaderObjectBase):string
+ {
+ if (this._blendMode == VertexAnimationMode.ABSOLUTE)
+ return this.getAbsoluteAGALCode(shaderObject);
+ else
+ return this.getAdditiveAGALCode(shaderObject);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public activate(shaderObject:ShaderObjectBase, stage:Stage)
+ {
+// var uID:number = pass._iUniqueId;
+// this._uploadNormals = this._useNormals[uID];
+// this._uploadTangents = this._useTangents[uID];
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public deactivate(shaderObject:ShaderObjectBase, stage:Stage)
+ {
+// var uID:number = pass._iUniqueId;
+// var index:number /*uint*/ = this._streamIndices[uID];
+// var context:IContextStageGL = stage.context;
+// context.setVertexBufferAt(index, null);
+// if (this._uploadNormals)
+// context.setVertexBufferAt(index + 1, null);
+// if (this._uploadTangents)
+// context.setVertexBufferAt(index + 2, null);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALFragmentCode(shaderObject:ShaderObjectBase, shadedTarget:string):string
+ {
+ return "";
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALUVCode(shaderObject:ShaderObjectBase):string
+ {
+ return "mov " + shaderObject.uvTarget + "," + shaderObject.uvSource + "\n";
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public doneAGALCode(shaderObject:ShaderObjectBase)
+ {
+
+ }
+
+ /**
+ * Generates the vertex AGAL code for absolute blending.
+ */
+ private getAbsoluteAGALCode(shaderObject:ShaderObjectBase):string
+ {
+ var code:string = "";
+ var temp1:string = this._pFindTempReg(shaderObject.animationTargetRegisters);
+ var temp2:string = this._pFindTempReg(shaderObject.animationTargetRegisters, temp1);
+ var regs:Array = new Array("x", "y", "z", "w");
+ var len:number /*uint*/ = shaderObject.animatableAttributes.length;
+ var constantReg:string = "vc" + shaderObject.numUsedVertexConstants;
+
+ if (len > 2)
+ len = 2;
+ var streamIndex:number /*uint*/ = shaderObject.numUsedStreams;
+
+ for (var i:number /*uint*/ = 0; i < len; ++i) {
+ code += "mul " + temp1 + ", " + shaderObject.animatableAttributes[i] + ", " + constantReg + "." + regs[0] + "\n";
+
+ for (var j:number /*uint*/ = 1; j < this._numPoses; ++j) {
+ code += "mul " + temp2 + ", va" + streamIndex + ", " + constantReg + "." + regs[j] + "\n";
+
+ if (j < this._numPoses - 1)
+ code += "add " + temp1 + ", " + temp1 + ", " + temp2 + "\n";
+
+ ++streamIndex;
+ }
+
+ code += "add " + shaderObject.animationTargetRegisters[i] + ", " + temp1 + ", " + temp2 + "\n";
+ }
+
+ // add code for bitangents if tangents are used
+ if (shaderObject.tangentDependencies > 0 || shaderObject.outputsNormals) {
+ code += "dp3 " + temp1 + ".x, " + shaderObject.animatableAttributes[2] + ", " + shaderObject.animationTargetRegisters[1] + "\n" +
+ "mul " + temp1 + ", " + shaderObject.animationTargetRegisters[1] + ", " + temp1 + ".x\n" +
+ "sub " + shaderObject.animationTargetRegisters[2] + ", " + shaderObject.animationTargetRegisters[2] + ", " + temp1 + "\n";
+ }
+ return code;
+ }
+
+ /**
+ * Generates the vertex AGAL code for additive blending.
+ */
+ private getAdditiveAGALCode(shaderObject:ShaderObjectBase):string
+ {
+ var code:string = "";
+ var len:number /*uint*/ = shaderObject.animatableAttributes.length;
+ var regs:Array = ["x", "y", "z", "w"];
+ var temp1:string = this._pFindTempReg(shaderObject.animationTargetRegisters);
+ var k:number /*uint*/;
+
+ var streamIndex:number /*uint*/ = shaderObject.numUsedStreams;
+
+ if (len > 2)
+ len = 2;
+
+ code += "mov " + shaderObject.animationTargetRegisters[0] + ", " + shaderObject.animatableAttributes[0] + "\n";
+ if (shaderObject.normalDependencies > 0)
+ code += "mov " + shaderObject.animationTargetRegisters[1] + ", " + shaderObject.animatableAttributes[1] + "\n";
+
+ for (var i:number /*uint*/ = 0; i < len; ++i) {
+ for (var j:number /*uint*/ = 0; j < this._numPoses; ++j) {
+ code += "mul " + temp1 + ", va" + (streamIndex + k) + ", vc" + shaderObject.numUsedVertexConstants + "." + regs[j] + "\n" +
+ "add " + shaderObject.animationTargetRegisters[i] + ", " + shaderObject.animationTargetRegisters[i] + ", " + temp1 + "\n";
+ k++;
+ }
+ }
+
+ if (shaderObject.tangentDependencies > 0 || shaderObject.outputsNormals) {
+ code += "dp3 " + temp1 + ".x, " + shaderObject.animatableAttributes[2] + ", " + shaderObject.animationTargetRegisters[1] + "\n" +
+ "mul " + temp1 + ", " + shaderObject.animationTargetRegisters[1] + ", " + temp1 + ".x\n" +
+ "sub " + shaderObject.animationTargetRegisters[2] + ", " + shaderObject.animatableAttributes[2] + ", " + temp1 + "\n";
+ }
+
+ return code;
+ }
+}
+
+export = VertexAnimationSet;
\ No newline at end of file
diff --git a/lib/animators/VertexAnimator.js b/lib/animators/VertexAnimator.js
new file mode 100755
index 000000000..3d7573ded
--- /dev/null
+++ b/lib/animators/VertexAnimator.js
@@ -0,0 +1,144 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var TriangleSubGeometry = require("awayjs-core/lib/core/base/TriangleSubGeometry");
+var AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+var VertexDataPool = require("awayjs-stagegl/lib/core/pool/VertexDataPool");
+var ContextGLProgramType = require("awayjs-stagegl/lib/core/stagegl/ContextGLProgramType");
+var VertexAnimationMode = require("awayjs-renderergl/lib/animators/data/VertexAnimationMode");
+/**
+ * Provides an interface for assigning vertex-based animation data sets to mesh-based entity objects
+ * and controlling the various available states of animation through an interative playhead that can be
+ * automatically updated or manually triggered.
+ */
+var VertexAnimator = (function (_super) {
+ __extends(VertexAnimator, _super);
+ /**
+ * Creates a new VertexAnimator
object.
+ *
+ * @param vertexAnimationSet The animation data set containing the vertex animations used by the animator.
+ */
+ function VertexAnimator(vertexAnimationSet) {
+ _super.call(this, vertexAnimationSet);
+ this._poses = new Array();
+ this._weights = Array(1, 0, 0, 0);
+ this._vertexAnimationSet = vertexAnimationSet;
+ this._numPoses = vertexAnimationSet.numPoses;
+ this._blendMode = vertexAnimationSet.blendMode;
+ }
+ /**
+ * @inheritDoc
+ */
+ VertexAnimator.prototype.clone = function () {
+ return new VertexAnimator(this._vertexAnimationSet);
+ };
+ /**
+ * Plays a sequence with a given name. If the sequence is not found, it may not be loaded yet, and it will retry every frame.
+ * @param sequenceName The name of the clip to be played.
+ */
+ VertexAnimator.prototype.play = function (name, transition, offset) {
+ if (transition === void 0) { transition = null; }
+ if (offset === void 0) { offset = NaN; }
+ if (this._pActiveAnimationName == name)
+ return;
+ this._pActiveAnimationName = name;
+ //TODO: implement transitions in vertex animator
+ if (!this._pAnimationSet.hasAnimation(name))
+ throw new Error("Animation root node " + name + " not found!");
+ this._pActiveNode = this._pAnimationSet.getAnimation(name);
+ this._pActiveState = this.getAnimationState(this._pActiveNode);
+ if (this.updatePosition) {
+ //update straight away to reset position deltas
+ this._pActiveState.update(this._pAbsoluteTime);
+ this._pActiveState.positionDelta;
+ }
+ this._activeVertexState = this._pActiveState;
+ this.start();
+ //apply a time offset if specified
+ if (!isNaN(offset))
+ this.reset(name, offset);
+ };
+ /**
+ * @inheritDoc
+ */
+ VertexAnimator.prototype._pUpdateDeltaTime = function (dt) {
+ _super.prototype._pUpdateDeltaTime.call(this, dt);
+ var geometryFlag = false;
+ if (this._poses[0] != this._activeVertexState.currentGeometry) {
+ this._poses[0] = this._activeVertexState.currentGeometry;
+ geometryFlag = true;
+ }
+ if (this._poses[1] != this._activeVertexState.nextGeometry) {
+ this._poses[1] = this._activeVertexState.nextGeometry;
+ geometryFlag = true;
+ }
+ this._weights[0] = 1 - (this._weights[1] = this._activeVertexState.blendWeight);
+ if (geometryFlag) {
+ //invalidate meshes
+ var mesh;
+ var len = this._pOwners.length;
+ for (var i = 0; i < len; i++) {
+ mesh = this._pOwners[i];
+ mesh._iInvalidateRenderableGeometries();
+ }
+ }
+ };
+ /**
+ * @inheritDoc
+ */
+ VertexAnimator.prototype.setRenderState = function (shaderObject, renderable, stage, camera, vertexConstantOffset /*int*/, vertexStreamOffset /*int*/) {
+ // todo: add code for when running on cpu
+ // if no poses defined, set temp data
+ if (!this._poses.length) {
+ this.setNullPose(shaderObject, renderable, stage, vertexConstantOffset, vertexStreamOffset);
+ return;
+ }
+ // this type of animation can only be SubMesh
+ var subMesh = renderable.subMesh;
+ var subGeom;
+ var i /*uint*/;
+ var len = this._numPoses;
+ stage.context.setProgramConstantsFromArray(ContextGLProgramType.VERTEX, vertexConstantOffset, this._weights, 1);
+ if (this._blendMode == VertexAnimationMode.ABSOLUTE)
+ i = 1;
+ else
+ i = 0;
+ for (; i < len; ++i) {
+ subGeom = this._poses[i].subGeometries[subMesh._iIndex] || subMesh.subGeometry;
+ stage.context.activateBuffer(vertexStreamOffset++, VertexDataPool.getItem(subGeom, renderable.getIndexData(), TriangleSubGeometry.POSITION_DATA), subGeom.getOffset(TriangleSubGeometry.POSITION_DATA), TriangleSubGeometry.POSITION_FORMAT);
+ if (shaderObject.normalDependencies > 0)
+ stage.context.activateBuffer(vertexStreamOffset++, VertexDataPool.getItem(subGeom, renderable.getIndexData(), TriangleSubGeometry.NORMAL_DATA), subGeom.getOffset(TriangleSubGeometry.NORMAL_DATA), TriangleSubGeometry.NORMAL_FORMAT);
+ }
+ };
+ VertexAnimator.prototype.setNullPose = function (shaderObject, renderable, stage, vertexConstantOffset /*int*/, vertexStreamOffset /*int*/) {
+ stage.context.setProgramConstantsFromArray(ContextGLProgramType.VERTEX, vertexConstantOffset, this._weights, 1);
+ if (this._blendMode == VertexAnimationMode.ABSOLUTE) {
+ var len = this._numPoses;
+ for (var i = 1; i < len; ++i) {
+ stage.context.activateBuffer(vertexStreamOffset++, renderable.getVertexData(TriangleSubGeometry.POSITION_DATA), renderable.getVertexOffset(TriangleSubGeometry.POSITION_DATA), TriangleSubGeometry.POSITION_FORMAT);
+ if (shaderObject.normalDependencies > 0)
+ stage.context.activateBuffer(vertexStreamOffset++, renderable.getVertexData(TriangleSubGeometry.NORMAL_DATA), renderable.getVertexOffset(TriangleSubGeometry.NORMAL_DATA), TriangleSubGeometry.NORMAL_FORMAT);
+ }
+ }
+ // todo: set temp data for additive?
+ };
+ /**
+ * Verifies if the animation will be used on cpu. Needs to be true for all passes for a material to be able to use it on gpu.
+ * Needs to be called if gpu code is potentially required.
+ */
+ VertexAnimator.prototype.testGPUCompatibility = function (shaderObject) {
+ };
+ VertexAnimator.prototype.getRenderableSubGeometry = function (renderable, sourceSubGeometry) {
+ if (this._blendMode == VertexAnimationMode.ABSOLUTE && this._poses.length)
+ return this._poses[0].subGeometries[renderable.subMesh._iIndex] || sourceSubGeometry;
+ //nothing to do here
+ return sourceSubGeometry;
+ };
+ return VertexAnimator;
+})(AnimatorBase);
+module.exports = VertexAnimator;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/vertexanimator.ts"],"names":["VertexAnimator","VertexAnimator.constructor","VertexAnimator.clone","VertexAnimator.play","VertexAnimator._pUpdateDeltaTime","VertexAnimator.setRenderState","VertexAnimator.setNullPose","VertexAnimator.testGPUCompatibility","VertexAnimator.getRenderableSubGeometry"],"mappings":"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","file":"animators/VertexAnimator.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Geometry\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/base/Geometry\");\nimport SubGeometryBase\t\t\t\t\t= require(\"awayjs-core/lib/core/base/SubGeometryBase\");\nimport TriangleSubGeometry\t\t\t\t= require(\"awayjs-core/lib/core/base/TriangleSubGeometry\");\nimport TriangleSubMesh\t\t\t\t\t= require(\"awayjs-core/lib/core/base/TriangleSubMesh\");\nimport Camera\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Camera\");\nimport Mesh\t\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Mesh\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport TriangleSubMeshRenderable\t\t= require(\"awayjs-stagegl/lib/core/pool/TriangleSubMeshRenderable\");\nimport RenderableBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/RenderableBase\");\nimport VertexDataPool\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/VertexDataPool\");\nimport ContextGLProgramType\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/ContextGLProgramType\");\nimport IContextStageGL\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/IContextStageGL\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\n\nimport VertexAnimationSet\t\t\t\t= require(\"awayjs-renderergl/lib/animators/VertexAnimationSet\");\nimport VertexAnimationMode\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/VertexAnimationMode\");\nimport IVertexAnimationState\t\t\t= require(\"awayjs-renderergl/lib/animators/states/IVertexAnimationState\");\nimport IAnimationTransition\t\t\t\t= require(\"awayjs-renderergl/lib/animators/transitions/IAnimationTransition\");\n\n/**\n * Provides an interface for assigning vertex-based animation data sets to mesh-based entity objects\n * and controlling the various available states of animation through an interative playhead that can be\n * automatically updated or manually triggered.\n */\nclass VertexAnimator extends AnimatorBase\n{\n\tprivate _vertexAnimationSet:VertexAnimationSet;\n\tprivate _poses:Array<Geometry> = new Array<Geometry>();\n\tprivate _weights:Array<number> = Array<number>(1, 0, 0, 0);\n\tprivate _numPoses:number /*uint*/;\n\tprivate _blendMode:string;\n\tprivate _activeVertexState:IVertexAnimationState;\n\n\t/**\n\t * Creates a new <code>VertexAnimator</code> object.\n\t *\n\t * @param vertexAnimationSet The animation data set containing the vertex animations used by the animator.\n\t */\n\tconstructor(vertexAnimationSet:VertexAnimationSet)\n\t{\n\t\tsuper(vertexAnimationSet);\n\n\t\tthis._vertexAnimationSet = vertexAnimationSet;\n\t\tthis._numPoses = vertexAnimationSet.numPoses;\n\t\tthis._blendMode = vertexAnimationSet.blendMode;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic clone():AnimatorBase\n\t{\n\t\treturn new VertexAnimator(this._vertexAnimationSet);\n\t}\n\n\t/**\n\t * Plays a sequence with a given name. If the sequence is not found, it may not be loaded yet, and it will retry every frame.\n\t * @param sequenceName The name of the clip to be played.\n\t */\n\tpublic play(name:string, transition:IAnimationTransition = null, offset:number = NaN)\n\t{\n\t\tif (this._pActiveAnimationName == name)\n\t\t\treturn;\n\n\t\tthis._pActiveAnimationName = name;\n\n\t\t//TODO: implement transitions in vertex animator\n\n\t\tif (!this._pAnimationSet.hasAnimation(name))\n\t\t\tthrow new Error(\"Animation root node \" + name + \" not found!\");\n\n\t\tthis._pActiveNode = this._pAnimationSet.getAnimation(name);\n\n\t\tthis._pActiveState = this.getAnimationState(this._pActiveNode);\n\n\t\tif (this.updatePosition) {\n\t\t\t//update straight away to reset position deltas\n\t\t\tthis._pActiveState.update(this._pAbsoluteTime);\n\t\t\tthis._pActiveState.positionDelta;\n\t\t}\n\n\t\tthis._activeVertexState = <IVertexAnimationState> this._pActiveState;\n\n\t\tthis.start();\n\n\t\t//apply a time offset if specified\n\t\tif (!isNaN(offset))\n\t\t\tthis.reset(name, offset);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _pUpdateDeltaTime(dt:number)\n\t{\n\t\tsuper._pUpdateDeltaTime(dt);\n\n\t\tvar geometryFlag:boolean = false;\n\n\t\tif (this._poses[0] != this._activeVertexState.currentGeometry) {\n\t\t\tthis._poses[0] = this._activeVertexState.currentGeometry;\n\t\t\tgeometryFlag = true;\n\t\t}\n\n\t\tif (this._poses[1] != this._activeVertexState.nextGeometry) {\n\t\t\tthis._poses[1] = this._activeVertexState.nextGeometry;\n\t\t\tgeometryFlag = true;\n\t\t}\n\n\t\tthis._weights[0] = 1 - (this._weights[1] = this._activeVertexState.blendWeight);\n\n\t\tif (geometryFlag) {\n\t\t\t//invalidate meshes\n\t\t\tvar mesh:Mesh;\n\t\t\tvar len:number = this._pOwners.length;\n\t\t\tfor (var i:number = 0; i < len; i++) {\n\t\t\t\tmesh = this._pOwners[i];\n\t\t\t\tmesh._iInvalidateRenderableGeometries();\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic setRenderState(shaderObject:ShaderObjectBase, renderable:RenderableBase, stage:Stage, camera:Camera, vertexConstantOffset:number /*int*/, vertexStreamOffset:number /*int*/)\n\t{\n\t\t// todo: add code for when running on cpu\n\n\t\t// if no poses defined, set temp data\n\t\tif (!this._poses.length) {\n\t\t\tthis.setNullPose(shaderObject, renderable, stage, vertexConstantOffset, vertexStreamOffset);\n\t\t\treturn;\n\t\t}\n\n\t\t// this type of animation can only be SubMesh\n\t\tvar subMesh:TriangleSubMesh = <TriangleSubMesh> (<TriangleSubMeshRenderable> renderable).subMesh;\n\t\tvar subGeom:SubGeometryBase;\n\t\tvar i:number /*uint*/;\n\t\tvar len:number /*uint*/ = this._numPoses;\n\n\t\t(<IContextStageGL> stage.context).setProgramConstantsFromArray(ContextGLProgramType.VERTEX, vertexConstantOffset, this._weights, 1);\n\n\t\tif (this._blendMode == VertexAnimationMode.ABSOLUTE)\n\t\t\ti = 1;\n\t\telse\n\t\t\ti = 0;\n\n\t\tfor (; i < len; ++i) {\n\t\t\tsubGeom = this._poses[i].subGeometries[subMesh._iIndex] || subMesh.subGeometry;\n\n\t\t\t(<IContextStageGL> stage.context).activateBuffer(vertexStreamOffset++, VertexDataPool.getItem(subGeom, renderable.getIndexData(), TriangleSubGeometry.POSITION_DATA), subGeom.getOffset(TriangleSubGeometry.POSITION_DATA), TriangleSubGeometry.POSITION_FORMAT);\n\n\t\t\tif (shaderObject.normalDependencies > 0)\n\t\t\t\t(<IContextStageGL> stage.context).activateBuffer(vertexStreamOffset++, VertexDataPool.getItem(subGeom, renderable.getIndexData(), TriangleSubGeometry.NORMAL_DATA), subGeom.getOffset(TriangleSubGeometry.NORMAL_DATA), TriangleSubGeometry.NORMAL_FORMAT);\n\t\t}\n\t}\n\n\tprivate setNullPose(shaderObject:ShaderObjectBase, renderable:RenderableBase, stage:Stage, vertexConstantOffset:number /*int*/, vertexStreamOffset:number /*int*/)\n\t{\n\t\t(<IContextStageGL> stage.context).setProgramConstantsFromArray(ContextGLProgramType.VERTEX, vertexConstantOffset, this._weights, 1);\n\n\t\tif (this._blendMode == VertexAnimationMode.ABSOLUTE) {\n\t\t\tvar len:number /*uint*/ = this._numPoses;\n\t\t\tfor (var i:number /*uint*/ = 1; i < len; ++i) {\n\t\t\t\t(<IContextStageGL> stage.context).activateBuffer(vertexStreamOffset++, renderable.getVertexData(TriangleSubGeometry.POSITION_DATA), renderable.getVertexOffset(TriangleSubGeometry.POSITION_DATA), TriangleSubGeometry.POSITION_FORMAT);\n\n\t\t\t\tif (shaderObject.normalDependencies > 0)\n\t\t\t\t\t(<IContextStageGL> stage.context).activateBuffer(vertexStreamOffset++, renderable.getVertexData(TriangleSubGeometry.NORMAL_DATA), renderable.getVertexOffset(TriangleSubGeometry.NORMAL_DATA), TriangleSubGeometry.NORMAL_FORMAT);\n\t\t\t}\n\t\t}\n\t\t// todo: set temp data for additive?\n\t}\n\n\t/**\n\t * Verifies if the animation will be used on cpu. Needs to be true for all passes for a material to be able to use it on gpu.\n\t * Needs to be called if gpu code is potentially required.\n\t */\n\tpublic testGPUCompatibility(shaderObject:ShaderObjectBase)\n\t{\n\t}\n\n\tpublic getRenderableSubGeometry(renderable:TriangleSubMeshRenderable, sourceSubGeometry:TriangleSubGeometry):TriangleSubGeometry\n\t{\n\t\tif (this._blendMode == VertexAnimationMode.ABSOLUTE && this._poses.length)\n\t\t\treturn <TriangleSubGeometry> this._poses[0].subGeometries[renderable.subMesh._iIndex] || sourceSubGeometry;\n\n\t\t//nothing to do here\n\t\treturn sourceSubGeometry;\n\t}\n}\n\nexport = VertexAnimator;"]}
\ No newline at end of file
diff --git a/lib/animators/VertexAnimator.ts b/lib/animators/VertexAnimator.ts
new file mode 100644
index 000000000..e713fa7b7
--- /dev/null
+++ b/lib/animators/VertexAnimator.ts
@@ -0,0 +1,195 @@
+import Geometry = require("awayjs-core/lib/core/base/Geometry");
+import SubGeometryBase = require("awayjs-core/lib/core/base/SubGeometryBase");
+import TriangleSubGeometry = require("awayjs-core/lib/core/base/TriangleSubGeometry");
+import TriangleSubMesh = require("awayjs-core/lib/core/base/TriangleSubMesh");
+import Camera = require("awayjs-core/lib/entities/Camera");
+import Mesh = require("awayjs-core/lib/entities/Mesh");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import TriangleSubMeshRenderable = require("awayjs-stagegl/lib/core/pool/TriangleSubMeshRenderable");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import VertexDataPool = require("awayjs-stagegl/lib/core/pool/VertexDataPool");
+import ContextGLProgramType = require("awayjs-stagegl/lib/core/stagegl/ContextGLProgramType");
+import IContextStageGL = require("awayjs-stagegl/lib/core/stagegl/IContextStageGL");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+
+import VertexAnimationSet = require("awayjs-renderergl/lib/animators/VertexAnimationSet");
+import VertexAnimationMode = require("awayjs-renderergl/lib/animators/data/VertexAnimationMode");
+import IVertexAnimationState = require("awayjs-renderergl/lib/animators/states/IVertexAnimationState");
+import IAnimationTransition = require("awayjs-renderergl/lib/animators/transitions/IAnimationTransition");
+
+/**
+ * Provides an interface for assigning vertex-based animation data sets to mesh-based entity objects
+ * and controlling the various available states of animation through an interative playhead that can be
+ * automatically updated or manually triggered.
+ */
+class VertexAnimator extends AnimatorBase
+{
+ private _vertexAnimationSet:VertexAnimationSet;
+ private _poses:Array = new Array();
+ private _weights:Array = Array(1, 0, 0, 0);
+ private _numPoses:number /*uint*/;
+ private _blendMode:string;
+ private _activeVertexState:IVertexAnimationState;
+
+ /**
+ * Creates a new VertexAnimator
object.
+ *
+ * @param vertexAnimationSet The animation data set containing the vertex animations used by the animator.
+ */
+ constructor(vertexAnimationSet:VertexAnimationSet)
+ {
+ super(vertexAnimationSet);
+
+ this._vertexAnimationSet = vertexAnimationSet;
+ this._numPoses = vertexAnimationSet.numPoses;
+ this._blendMode = vertexAnimationSet.blendMode;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public clone():AnimatorBase
+ {
+ return new VertexAnimator(this._vertexAnimationSet);
+ }
+
+ /**
+ * Plays a sequence with a given name. If the sequence is not found, it may not be loaded yet, and it will retry every frame.
+ * @param sequenceName The name of the clip to be played.
+ */
+ public play(name:string, transition:IAnimationTransition = null, offset:number = NaN)
+ {
+ if (this._pActiveAnimationName == name)
+ return;
+
+ this._pActiveAnimationName = name;
+
+ //TODO: implement transitions in vertex animator
+
+ if (!this._pAnimationSet.hasAnimation(name))
+ throw new Error("Animation root node " + name + " not found!");
+
+ this._pActiveNode = this._pAnimationSet.getAnimation(name);
+
+ this._pActiveState = this.getAnimationState(this._pActiveNode);
+
+ if (this.updatePosition) {
+ //update straight away to reset position deltas
+ this._pActiveState.update(this._pAbsoluteTime);
+ this._pActiveState.positionDelta;
+ }
+
+ this._activeVertexState = this._pActiveState;
+
+ this.start();
+
+ //apply a time offset if specified
+ if (!isNaN(offset))
+ this.reset(name, offset);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pUpdateDeltaTime(dt:number)
+ {
+ super._pUpdateDeltaTime(dt);
+
+ var geometryFlag:boolean = false;
+
+ if (this._poses[0] != this._activeVertexState.currentGeometry) {
+ this._poses[0] = this._activeVertexState.currentGeometry;
+ geometryFlag = true;
+ }
+
+ if (this._poses[1] != this._activeVertexState.nextGeometry) {
+ this._poses[1] = this._activeVertexState.nextGeometry;
+ geometryFlag = true;
+ }
+
+ this._weights[0] = 1 - (this._weights[1] = this._activeVertexState.blendWeight);
+
+ if (geometryFlag) {
+ //invalidate meshes
+ var mesh:Mesh;
+ var len:number = this._pOwners.length;
+ for (var i:number = 0; i < len; i++) {
+ mesh = this._pOwners[i];
+ mesh._iInvalidateRenderableGeometries();
+ }
+ }
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public setRenderState(shaderObject:ShaderObjectBase, renderable:RenderableBase, stage:Stage, camera:Camera, vertexConstantOffset:number /*int*/, vertexStreamOffset:number /*int*/)
+ {
+ // todo: add code for when running on cpu
+
+ // if no poses defined, set temp data
+ if (!this._poses.length) {
+ this.setNullPose(shaderObject, renderable, stage, vertexConstantOffset, vertexStreamOffset);
+ return;
+ }
+
+ // this type of animation can only be SubMesh
+ var subMesh:TriangleSubMesh = ( renderable).subMesh;
+ var subGeom:SubGeometryBase;
+ var i:number /*uint*/;
+ var len:number /*uint*/ = this._numPoses;
+
+ ( stage.context).setProgramConstantsFromArray(ContextGLProgramType.VERTEX, vertexConstantOffset, this._weights, 1);
+
+ if (this._blendMode == VertexAnimationMode.ABSOLUTE)
+ i = 1;
+ else
+ i = 0;
+
+ for (; i < len; ++i) {
+ subGeom = this._poses[i].subGeometries[subMesh._iIndex] || subMesh.subGeometry;
+
+ ( stage.context).activateBuffer(vertexStreamOffset++, VertexDataPool.getItem(subGeom, renderable.getIndexData(), TriangleSubGeometry.POSITION_DATA), subGeom.getOffset(TriangleSubGeometry.POSITION_DATA), TriangleSubGeometry.POSITION_FORMAT);
+
+ if (shaderObject.normalDependencies > 0)
+ ( stage.context).activateBuffer(vertexStreamOffset++, VertexDataPool.getItem(subGeom, renderable.getIndexData(), TriangleSubGeometry.NORMAL_DATA), subGeom.getOffset(TriangleSubGeometry.NORMAL_DATA), TriangleSubGeometry.NORMAL_FORMAT);
+ }
+ }
+
+ private setNullPose(shaderObject:ShaderObjectBase, renderable:RenderableBase, stage:Stage, vertexConstantOffset:number /*int*/, vertexStreamOffset:number /*int*/)
+ {
+ ( stage.context).setProgramConstantsFromArray(ContextGLProgramType.VERTEX, vertexConstantOffset, this._weights, 1);
+
+ if (this._blendMode == VertexAnimationMode.ABSOLUTE) {
+ var len:number /*uint*/ = this._numPoses;
+ for (var i:number /*uint*/ = 1; i < len; ++i) {
+ ( stage.context).activateBuffer(vertexStreamOffset++, renderable.getVertexData(TriangleSubGeometry.POSITION_DATA), renderable.getVertexOffset(TriangleSubGeometry.POSITION_DATA), TriangleSubGeometry.POSITION_FORMAT);
+
+ if (shaderObject.normalDependencies > 0)
+ ( stage.context).activateBuffer(vertexStreamOffset++, renderable.getVertexData(TriangleSubGeometry.NORMAL_DATA), renderable.getVertexOffset(TriangleSubGeometry.NORMAL_DATA), TriangleSubGeometry.NORMAL_FORMAT);
+ }
+ }
+ // todo: set temp data for additive?
+ }
+
+ /**
+ * Verifies if the animation will be used on cpu. Needs to be true for all passes for a material to be able to use it on gpu.
+ * Needs to be called if gpu code is potentially required.
+ */
+ public testGPUCompatibility(shaderObject:ShaderObjectBase)
+ {
+ }
+
+ public getRenderableSubGeometry(renderable:TriangleSubMeshRenderable, sourceSubGeometry:TriangleSubGeometry):TriangleSubGeometry
+ {
+ if (this._blendMode == VertexAnimationMode.ABSOLUTE && this._poses.length)
+ return this._poses[0].subGeometries[renderable.subMesh._iIndex] || sourceSubGeometry;
+
+ //nothing to do here
+ return sourceSubGeometry;
+ }
+}
+
+export = VertexAnimator;
\ No newline at end of file
diff --git a/lib/animators/data/AnimationSubGeometry.js b/lib/animators/data/AnimationSubGeometry.js
new file mode 100755
index 000000000..8ed4d8fd5
--- /dev/null
+++ b/lib/animators/data/AnimationSubGeometry.js
@@ -0,0 +1,73 @@
+/**
+ * ...
+ */
+var AnimationSubGeometry = (function () {
+ function AnimationSubGeometry() {
+ this._pVertexBuffer = new Array(8);
+ this._pBufferContext = new Array(8);
+ this._pBufferDirty = new Array(8);
+ this.numProcessedVertices = 0;
+ this.previousTime = Number.NEGATIVE_INFINITY;
+ this.animationParticles = new Array();
+ for (var i = 0; i < 8; i++)
+ this._pBufferDirty[i] = true;
+ this._iUniqueId = AnimationSubGeometry.SUBGEOM_ID_COUNT++;
+ }
+ AnimationSubGeometry.prototype.createVertexData = function (numVertices /*uint*/, totalLenOfOneVertex /*uint*/) {
+ this._numVertices = numVertices;
+ this._totalLenOfOneVertex = totalLenOfOneVertex;
+ this._pVertexData = new Array(numVertices * totalLenOfOneVertex);
+ };
+ AnimationSubGeometry.prototype.activateVertexBuffer = function (index /*int*/, bufferOffset /*int*/, stage, format) {
+ var contextIndex = stage.stageIndex;
+ var context = stage.context;
+ var buffer = this._pVertexBuffer[contextIndex];
+ if (!buffer || this._pBufferContext[contextIndex] != context) {
+ buffer = this._pVertexBuffer[contextIndex] = context.createVertexBuffer(this._numVertices, this._totalLenOfOneVertex);
+ this._pBufferContext[contextIndex] = context;
+ this._pBufferDirty[contextIndex] = true;
+ }
+ if (this._pBufferDirty[contextIndex]) {
+ buffer.uploadFromArray(this._pVertexData, 0, this._numVertices);
+ this._pBufferDirty[contextIndex] = false;
+ }
+ context.setVertexBufferAt(index, buffer, bufferOffset, format);
+ };
+ AnimationSubGeometry.prototype.dispose = function () {
+ while (this._pVertexBuffer.length) {
+ var vertexBuffer = this._pVertexBuffer.pop();
+ if (vertexBuffer)
+ vertexBuffer.dispose();
+ }
+ };
+ AnimationSubGeometry.prototype.invalidateBuffer = function () {
+ for (var i = 0; i < 8; i++)
+ this._pBufferDirty[i] = true;
+ };
+ Object.defineProperty(AnimationSubGeometry.prototype, "vertexData", {
+ get: function () {
+ return this._pVertexData;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(AnimationSubGeometry.prototype, "numVertices", {
+ get: function () {
+ return this._numVertices;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(AnimationSubGeometry.prototype, "totalLenOfOneVertex", {
+ get: function () {
+ return this._totalLenOfOneVertex;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ AnimationSubGeometry.SUBGEOM_ID_COUNT = 0;
+ return AnimationSubGeometry;
+})();
+module.exports = AnimationSubGeometry;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/data/animationsubgeometry.ts"],"names":["AnimationSubGeometry","AnimationSubGeometry.constructor","AnimationSubGeometry.createVertexData","AnimationSubGeometry.activateVertexBuffer","AnimationSubGeometry.dispose","AnimationSubGeometry.invalidateBuffer","AnimationSubGeometry.vertexData","AnimationSubGeometry.numVertices","AnimationSubGeometry.totalLenOfOneVertex"],"mappings":"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","file":"animators/data/AnimationSubGeometry.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport IContextStageGL\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/IContextStageGL\");\nimport IVertexBuffer\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/IVertexBuffer\");\n\nimport ParticleAnimationData\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleAnimationData\");\n\n/**\n * ...\n */\nclass AnimationSubGeometry\n{\n\tpublic static SUBGEOM_ID_COUNT:number = 0;\n\n\tpublic _pVertexData:Array<number>;\n\n\tpublic _pVertexBuffer:Array<IVertexBuffer> = new Array<IVertexBuffer>(8);\n\tpublic _pBufferContext:Array<IContextStageGL> = new Array<IContextStageGL>(8);\n\tpublic _pBufferDirty:Array<boolean> = new Array<boolean>(8);\n\n\tprivate _numVertices:number /*uint*/;\n\n\tprivate _totalLenOfOneVertex:number /*uint*/;\n\n\tpublic numProcessedVertices:number /*int*/ = 0;\n\n\tpublic previousTime:number = Number.NEGATIVE_INFINITY;\n\n\tpublic animationParticles:Array<ParticleAnimationData> = new Array<ParticleAnimationData>();\n\n\t/**\n\t * An id for this animation subgeometry, used to identify animation subgeometries when using animation sets.\n\t *\n\t * @private\n\t */\n\tpublic _iUniqueId:number;//Arcane\n\n\tconstructor()\n\t{\n\t\tfor (var i:number /*int*/ = 0; i < 8; i++)\n\t\t\tthis._pBufferDirty[i] = true;\n\n\t\tthis._iUniqueId = AnimationSubGeometry.SUBGEOM_ID_COUNT++;\n\t}\n\n\tpublic createVertexData(numVertices:number /*uint*/, totalLenOfOneVertex:number /*uint*/)\n\t{\n\t\tthis._numVertices = numVertices;\n\t\tthis._totalLenOfOneVertex = totalLenOfOneVertex;\n\t\tthis._pVertexData = new Array<number>(numVertices*totalLenOfOneVertex);\n\t}\n\n\tpublic activateVertexBuffer(index:number /*int*/, bufferOffset:number /*int*/, stage:Stage, format:string)\n\t{\n\t\tvar contextIndex:number /*int*/ = stage.stageIndex;\n\t\tvar context:IContextStageGL = <IContextStageGL> stage.context;\n\n\t\tvar buffer:IVertexBuffer = this._pVertexBuffer[contextIndex];\n\t\tif (!buffer || this._pBufferContext[contextIndex] != context) {\n\t\t\tbuffer = this._pVertexBuffer[contextIndex] = context.createVertexBuffer(this._numVertices, this._totalLenOfOneVertex);\n\t\t\tthis._pBufferContext[contextIndex] = context;\n\t\t\tthis._pBufferDirty[contextIndex] = true;\n\t\t}\n\t\tif (this._pBufferDirty[contextIndex]) {\n\t\t\tbuffer.uploadFromArray(this._pVertexData, 0, this._numVertices);\n\t\t\tthis._pBufferDirty[contextIndex] = false;\n\t\t}\n\t\tcontext.setVertexBufferAt(index, buffer, bufferOffset, format);\n\t}\n\n\tpublic dispose()\n\t{\n\t\twhile (this._pVertexBuffer.length) {\n\t\t\tvar vertexBuffer:IVertexBuffer = this._pVertexBuffer.pop()\n\n\t\t\tif (vertexBuffer)\n\t\t\t\tvertexBuffer.dispose();\n\t\t}\n\t}\n\n\tpublic invalidateBuffer()\n\t{\n\t\tfor (var i:number /*int*/ = 0; i < 8; i++)\n\t\t\tthis._pBufferDirty[i] = true;\n\t}\n\n\tpublic get vertexData():Array<number>\n\t{\n\t\treturn this._pVertexData;\n\t}\n\n\tpublic get numVertices():number /*uint*/\n\t{\n\t\treturn this._numVertices;\n\t}\n\n\tpublic get totalLenOfOneVertex():number /*uint*/\n\t{\n\t\treturn this._totalLenOfOneVertex;\n\t}\n}\n\nexport = AnimationSubGeometry;"]}
\ No newline at end of file
diff --git a/lib/animators/data/AnimationSubGeometry.ts b/lib/animators/data/AnimationSubGeometry.ts
new file mode 100644
index 000000000..76b6c7e7e
--- /dev/null
+++ b/lib/animators/data/AnimationSubGeometry.ts
@@ -0,0 +1,102 @@
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import IContextStageGL = require("awayjs-stagegl/lib/core/stagegl/IContextStageGL");
+import IVertexBuffer = require("awayjs-stagegl/lib/core/stagegl/IVertexBuffer");
+
+import ParticleAnimationData = require("awayjs-renderergl/lib/animators/data/ParticleAnimationData");
+
+/**
+ * ...
+ */
+class AnimationSubGeometry
+{
+ public static SUBGEOM_ID_COUNT:number = 0;
+
+ public _pVertexData:Array;
+
+ public _pVertexBuffer:Array = new Array(8);
+ public _pBufferContext:Array = new Array(8);
+ public _pBufferDirty:Array = new Array(8);
+
+ private _numVertices:number /*uint*/;
+
+ private _totalLenOfOneVertex:number /*uint*/;
+
+ public numProcessedVertices:number /*int*/ = 0;
+
+ public previousTime:number = Number.NEGATIVE_INFINITY;
+
+ public animationParticles:Array = new Array();
+
+ /**
+ * An id for this animation subgeometry, used to identify animation subgeometries when using animation sets.
+ *
+ * @private
+ */
+ public _iUniqueId:number;//Arcane
+
+ constructor()
+ {
+ for (var i:number /*int*/ = 0; i < 8; i++)
+ this._pBufferDirty[i] = true;
+
+ this._iUniqueId = AnimationSubGeometry.SUBGEOM_ID_COUNT++;
+ }
+
+ public createVertexData(numVertices:number /*uint*/, totalLenOfOneVertex:number /*uint*/)
+ {
+ this._numVertices = numVertices;
+ this._totalLenOfOneVertex = totalLenOfOneVertex;
+ this._pVertexData = new Array(numVertices*totalLenOfOneVertex);
+ }
+
+ public activateVertexBuffer(index:number /*int*/, bufferOffset:number /*int*/, stage:Stage, format:string)
+ {
+ var contextIndex:number /*int*/ = stage.stageIndex;
+ var context:IContextStageGL = stage.context;
+
+ var buffer:IVertexBuffer = this._pVertexBuffer[contextIndex];
+ if (!buffer || this._pBufferContext[contextIndex] != context) {
+ buffer = this._pVertexBuffer[contextIndex] = context.createVertexBuffer(this._numVertices, this._totalLenOfOneVertex);
+ this._pBufferContext[contextIndex] = context;
+ this._pBufferDirty[contextIndex] = true;
+ }
+ if (this._pBufferDirty[contextIndex]) {
+ buffer.uploadFromArray(this._pVertexData, 0, this._numVertices);
+ this._pBufferDirty[contextIndex] = false;
+ }
+ context.setVertexBufferAt(index, buffer, bufferOffset, format);
+ }
+
+ public dispose()
+ {
+ while (this._pVertexBuffer.length) {
+ var vertexBuffer:IVertexBuffer = this._pVertexBuffer.pop()
+
+ if (vertexBuffer)
+ vertexBuffer.dispose();
+ }
+ }
+
+ public invalidateBuffer()
+ {
+ for (var i:number /*int*/ = 0; i < 8; i++)
+ this._pBufferDirty[i] = true;
+ }
+
+ public get vertexData():Array
+ {
+ return this._pVertexData;
+ }
+
+ public get numVertices():number /*uint*/
+ {
+ return this._numVertices;
+ }
+
+ public get totalLenOfOneVertex():number /*uint*/
+ {
+ return this._totalLenOfOneVertex;
+ }
+}
+
+export = AnimationSubGeometry;
\ No newline at end of file
diff --git a/lib/animators/data/ColorSegmentPoint.js b/lib/animators/data/ColorSegmentPoint.js
new file mode 100755
index 000000000..33f0b70cd
--- /dev/null
+++ b/lib/animators/data/ColorSegmentPoint.js
@@ -0,0 +1,27 @@
+var ColorSegmentPoint = (function () {
+ function ColorSegmentPoint(life, color) {
+ //0= 1)
+ throw (new Error("life exceeds range (0,1)"));
+ this._life = life;
+ this._color = color;
+ }
+ Object.defineProperty(ColorSegmentPoint.prototype, "color", {
+ get: function () {
+ return this._color;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ColorSegmentPoint.prototype, "life", {
+ get: function () {
+ return this._life;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ return ColorSegmentPoint;
+})();
+module.exports = ColorSegmentPoint;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9kYXRhL2NvbG9yc2VnbWVudHBvaW50LnRzIl0sIm5hbWVzIjpbIkNvbG9yU2VnbWVudFBvaW50IiwiQ29sb3JTZWdtZW50UG9pbnQuY29uc3RydWN0b3IiLCJDb2xvclNlZ21lbnRQb2ludC5jb2xvciIsIkNvbG9yU2VnbWVudFBvaW50LmxpZmUiXSwibWFwcGluZ3MiOiJBQUVBLElBQU0saUJBQWlCO0lBS3RCQSxTQUxLQSxpQkFBaUJBLENBS1ZBLElBQVdBLEVBQUVBLEtBQW9CQTtRQUU1Q0MsQUFDQUEsVUFEVUE7UUFDVkEsRUFBRUEsQ0FBQ0EsQ0FBQ0EsSUFBSUEsSUFBSUEsQ0FBQ0EsSUFBSUEsSUFBSUEsSUFBSUEsQ0FBQ0EsQ0FBQ0E7WUFDMUJBLE1BQUtBLENBQUNBLElBQUlBLEtBQUtBLENBQUNBLDBCQUEwQkEsQ0FBQ0EsQ0FBQ0EsQ0FBQ0E7UUFDOUNBLElBQUlBLENBQUNBLEtBQUtBLEdBQUdBLElBQUlBLENBQUNBO1FBQ2xCQSxJQUFJQSxDQUFDQSxNQUFNQSxHQUFHQSxLQUFLQSxDQUFDQTtJQUNyQkEsQ0FBQ0E7SUFFREQsc0JBQVdBLG9DQUFLQTthQUFoQkE7WUFFQ0UsTUFBTUEsQ0FBQ0EsSUFBSUEsQ0FBQ0EsTUFBTUEsQ0FBQ0E7UUFDcEJBLENBQUNBOzs7T0FBQUY7SUFFREEsc0JBQVdBLG1DQUFJQTthQUFmQTtZQUVDRyxNQUFNQSxDQUFDQSxJQUFJQSxDQUFDQSxLQUFLQSxDQUFDQTtRQUNuQkEsQ0FBQ0E7OztPQUFBSDtJQUVGQSx3QkFBQ0E7QUFBREEsQ0F4QkEsQUF3QkNBLElBQUE7QUFFRCxBQUEyQixpQkFBbEIsaUJBQWlCLENBQUMiLCJmaWxlIjoiYW5pbWF0b3JzL2RhdGEvQ29sb3JTZWdtZW50UG9pbnQuanMiLCJzb3VyY2VSb290IjoiL1VzZXJzL3JvYmJhdGVtYW4vV2Vic3Rvcm1Qcm9qZWN0cy9hd2F5anMtcmVuZGVyZXJnbC8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQ29sb3JUcmFuc2Zvcm1cdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLWNvcmUvbGliL2NvcmUvZ2VvbS9Db2xvclRyYW5zZm9ybVwiKTtcblxuY2xhc3MgQ29sb3JTZWdtZW50UG9pbnRcbntcblx0cHJpdmF0ZSBfY29sb3I6Q29sb3JUcmFuc2Zvcm07XG5cdHByaXZhdGUgX2xpZmU6bnVtYmVyO1xuXG5cdGNvbnN0cnVjdG9yKGxpZmU6bnVtYmVyLCBjb2xvcjpDb2xvclRyYW5zZm9ybSlcblx0e1xuXHRcdC8vMDxsaWZlPDFcblx0XHRpZiAobGlmZSA8PSAwIHx8IGxpZmUgPj0gMSlcblx0XHRcdHRocm93KG5ldyBFcnJvcihcImxpZmUgZXhjZWVkcyByYW5nZSAoMCwxKVwiKSk7XG5cdFx0dGhpcy5fbGlmZSA9IGxpZmU7XG5cdFx0dGhpcy5fY29sb3IgPSBjb2xvcjtcblx0fVxuXG5cdHB1YmxpYyBnZXQgY29sb3IoKTpDb2xvclRyYW5zZm9ybVxuXHR7XG5cdFx0cmV0dXJuIHRoaXMuX2NvbG9yO1xuXHR9XG5cblx0cHVibGljIGdldCBsaWZlKCk6bnVtYmVyXG5cdHtcblx0XHRyZXR1cm4gdGhpcy5fbGlmZTtcblx0fVxuXG59XG5cbmV4cG9ydCA9IENvbG9yU2VnbWVudFBvaW50OyJdfQ==
\ No newline at end of file
diff --git a/lib/animators/data/ColorSegmentPoint.ts b/lib/animators/data/ColorSegmentPoint.ts
new file mode 100644
index 000000000..025641855
--- /dev/null
+++ b/lib/animators/data/ColorSegmentPoint.ts
@@ -0,0 +1,29 @@
+import ColorTransform = require("awayjs-core/lib/core/geom/ColorTransform");
+
+class ColorSegmentPoint
+{
+ private _color:ColorTransform;
+ private _life:number;
+
+ constructor(life:number, color:ColorTransform)
+ {
+ //0= 1)
+ throw(new Error("life exceeds range (0,1)"));
+ this._life = life;
+ this._color = color;
+ }
+
+ public get color():ColorTransform
+ {
+ return this._color;
+ }
+
+ public get life():number
+ {
+ return this._life;
+ }
+
+}
+
+export = ColorSegmentPoint;
\ No newline at end of file
diff --git a/lib/animators/data/JointPose.js b/lib/animators/data/JointPose.js
new file mode 100755
index 000000000..aca5b0415
--- /dev/null
+++ b/lib/animators/data/JointPose.js
@@ -0,0 +1,57 @@
+var Matrix3D = require("awayjs-core/lib/core/geom/Matrix3D");
+var Quaternion = require("awayjs-core/lib/core/geom/Quaternion");
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+/**
+ * Contains transformation data for a skeleton joint, used for skeleton animation.
+ *
+ * @see away.animation.Skeleton
+ * @see away.animation.SkeletonJoint
+ *
+ * todo: support (uniform) scale
+ */
+var JointPose = (function () {
+ function JointPose() {
+ /**
+ * The rotation of the pose stored as a quaternion
+ */
+ this.orientation = new Quaternion();
+ /**
+ * The translation of the pose
+ */
+ this.translation = new Vector3D();
+ }
+ /**
+ * Converts the transformation to a Matrix3D representation.
+ *
+ * @param target An optional target matrix to store the transformation. If not provided, it will create a new instance.
+ * @return The transformation matrix of the pose.
+ */
+ JointPose.prototype.toMatrix3D = function (target) {
+ if (target === void 0) { target = null; }
+ if (target == null)
+ target = new Matrix3D();
+ this.orientation.toMatrix3D(target);
+ target.appendTranslation(this.translation.x, this.translation.y, this.translation.z);
+ return target;
+ };
+ /**
+ * Copies the transformation data from a source pose object into the existing pose object.
+ *
+ * @param pose The source pose to copy from.
+ */
+ JointPose.prototype.copyFrom = function (pose) {
+ var or = pose.orientation;
+ var tr = pose.translation;
+ this.orientation.x = or.x;
+ this.orientation.y = or.y;
+ this.orientation.z = or.z;
+ this.orientation.w = or.w;
+ this.translation.x = tr.x;
+ this.translation.y = tr.y;
+ this.translation.z = tr.z;
+ };
+ return JointPose;
+})();
+module.exports = JointPose;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9kYXRhL2pvaW50cG9zZS50cyJdLCJuYW1lcyI6WyJKb2ludFBvc2UiLCJKb2ludFBvc2UuY29uc3RydWN0b3IiLCJKb2ludFBvc2UudG9NYXRyaXgzRCIsIkpvaW50UG9zZS5jb3B5RnJvbSJdLCJtYXBwaW5ncyI6IkFBQUEsSUFBTyxRQUFRLFdBQWlCLG9DQUFvQyxDQUFDLENBQUM7QUFDdEUsSUFBTyxVQUFVLFdBQWdCLHNDQUFzQyxDQUFDLENBQUM7QUFDekUsSUFBTyxRQUFRLFdBQWlCLG9DQUFvQyxDQUFDLENBQUM7QUFFdEUsQUFRQTs7Ozs7OztHQURHO0lBQ0csU0FBUztJQWlCZEEsU0FqQktBLFNBQVNBO1FBT2RDOztXQUVHQTtRQUNJQSxnQkFBV0EsR0FBY0EsSUFBSUEsVUFBVUEsRUFBRUEsQ0FBQ0E7UUFFakRBOztXQUVHQTtRQUNJQSxnQkFBV0EsR0FBWUEsSUFBSUEsUUFBUUEsRUFBRUEsQ0FBQ0E7SUFLN0NBLENBQUNBO0lBRUREOzs7OztPQUtHQTtJQUNJQSw4QkFBVUEsR0FBakJBLFVBQWtCQSxNQUFzQkE7UUFBdEJFLHNCQUFzQkEsR0FBdEJBLGFBQXNCQTtRQUV2Q0EsRUFBRUEsQ0FBQ0EsQ0FBQ0EsTUFBTUEsSUFBSUEsSUFBSUEsQ0FBQ0E7WUFDbEJBLE1BQU1BLEdBQUdBLElBQUlBLFFBQVFBLEVBQUVBLENBQUNBO1FBRXpCQSxJQUFJQSxDQUFDQSxXQUFXQSxDQUFDQSxVQUFVQSxDQUFDQSxNQUFNQSxDQUFDQSxDQUFDQTtRQUNwQ0EsTUFBTUEsQ0FBQ0EsaUJBQWlCQSxDQUFDQSxJQUFJQSxDQUFDQSxXQUFXQSxDQUFDQSxDQUFDQSxFQUFFQSxJQUFJQSxDQUFDQSxXQUFXQSxDQUFDQSxDQUFDQSxFQUFFQSxJQUFJQSxDQUFDQSxXQUFXQSxDQUFDQSxDQUFDQSxDQUFDQSxDQUFDQTtRQUNyRkEsTUFBTUEsQ0FBQ0EsTUFBTUEsQ0FBQ0E7SUFDZkEsQ0FBQ0E7SUFFREY7Ozs7T0FJR0E7SUFDSUEsNEJBQVFBLEdBQWZBLFVBQWdCQSxJQUFjQTtRQUU3QkcsSUFBSUEsRUFBRUEsR0FBY0EsSUFBSUEsQ0FBQ0EsV0FBV0EsQ0FBQ0E7UUFDckNBLElBQUlBLEVBQUVBLEdBQVlBLElBQUlBLENBQUNBLFdBQVdBLENBQUNBO1FBQ25DQSxJQUFJQSxDQUFDQSxXQUFXQSxDQUFDQSxDQUFDQSxHQUFHQSxFQUFFQSxDQUFDQSxDQUFDQSxDQUFDQTtRQUMxQkEsSUFBSUEsQ0FBQ0EsV0FBV0EsQ0FBQ0EsQ0FBQ0EsR0FBR0EsRUFBRUEsQ0FBQ0EsQ0FBQ0EsQ0FBQ0E7UUFDMUJBLElBQUlBLENBQUNBLFdBQVdBLENBQUNBLENBQUNBLEdBQUdBLEVBQUVBLENBQUNBLENBQUNBLENBQUNBO1FBQzFCQSxJQUFJQSxDQUFDQSxXQUFXQSxDQUFDQSxDQUFDQSxHQUFHQSxFQUFFQSxDQUFDQSxDQUFDQSxDQUFDQTtRQUMxQkEsSUFBSUEsQ0FBQ0EsV0FBV0EsQ0FBQ0EsQ0FBQ0EsR0FBR0EsRUFBRUEsQ0FBQ0EsQ0FBQ0EsQ0FBQ0E7UUFDMUJBLElBQUlBLENBQUNBLFdBQVdBLENBQUNBLENBQUNBLEdBQUdBLEVBQUVBLENBQUNBLENBQUNBLENBQUNBO1FBQzFCQSxJQUFJQSxDQUFDQSxXQUFXQSxDQUFDQSxDQUFDQSxHQUFHQSxFQUFFQSxDQUFDQSxDQUFDQSxDQUFDQTtJQUMzQkEsQ0FBQ0E7SUFDRkgsZ0JBQUNBO0FBQURBLENBdkRBLEFBdURDQSxJQUFBO0FBRUQsQUFBbUIsaUJBQVYsU0FBUyxDQUFDIiwiZmlsZSI6ImFuaW1hdG9ycy9kYXRhL0pvaW50UG9zZS5qcyIsInNvdXJjZVJvb3QiOiIvVXNlcnMvcm9iYmF0ZW1hbi9XZWJzdG9ybVByb2plY3RzL2F3YXlqcy1yZW5kZXJlcmdsLyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBNYXRyaXgzRFx0XHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLWNvcmUvbGliL2NvcmUvZ2VvbS9NYXRyaXgzRFwiKTtcbmltcG9ydCBRdWF0ZXJuaW9uXHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLWNvcmUvbGliL2NvcmUvZ2VvbS9RdWF0ZXJuaW9uXCIpO1xuaW1wb3J0IFZlY3RvcjNEXHRcdFx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvY29yZS9nZW9tL1ZlY3RvcjNEXCIpO1xuXG4vKipcbiAqIENvbnRhaW5zIHRyYW5zZm9ybWF0aW9uIGRhdGEgZm9yIGEgc2tlbGV0b24gam9pbnQsIHVzZWQgZm9yIHNrZWxldG9uIGFuaW1hdGlvbi5cbiAqXG4gKiBAc2VlIGF3YXkuYW5pbWF0aW9uLlNrZWxldG9uXG4gKiBAc2VlIGF3YXkuYW5pbWF0aW9uLlNrZWxldG9uSm9pbnRcbiAqXG4gKiB0b2RvOiBzdXBwb3J0ICh1bmlmb3JtKSBzY2FsZVxuICovXG5jbGFzcyBKb2ludFBvc2Vcbntcblx0LyoqXG5cdCAqIFRoZSBuYW1lIG9mIHRoZSBqb2ludCB0byB3aGljaCB0aGUgcG9zZSBpcyBhc3NvY2lhdGVkXG5cdCAqL1xuXHRwdWJsaWMgbmFtZTpzdHJpbmc7IC8vIGludGVudGlvbiBpcyB0aGF0IHRoaXMgc2hvdWxkIGJlIHVzZWQgb25seSBhdCBsb2FkIHRpbWUsIG5vdCBpbiB0aGUgbWFpbiBsb29wXG5cblx0LyoqXG5cdCAqIFRoZSByb3RhdGlvbiBvZiB0aGUgcG9zZSBzdG9yZWQgYXMgYSBxdWF0ZXJuaW9uXG5cdCAqL1xuXHRwdWJsaWMgb3JpZW50YXRpb246UXVhdGVybmlvbiA9IG5ldyBRdWF0ZXJuaW9uKCk7XG5cblx0LyoqXG5cdCAqIFRoZSB0cmFuc2xhdGlvbiBvZiB0aGUgcG9zZVxuXHQgKi9cblx0cHVibGljIHRyYW5zbGF0aW9uOlZlY3RvcjNEID0gbmV3IFZlY3RvcjNEKCk7XG5cblx0Y29uc3RydWN0b3IoKVxuXHR7XG5cblx0fVxuXG5cdC8qKlxuXHQgKiBDb252ZXJ0cyB0aGUgdHJhbnNmb3JtYXRpb24gdG8gYSBNYXRyaXgzRCByZXByZXNlbnRhdGlvbi5cblx0ICpcblx0ICogQHBhcmFtIHRhcmdldCBBbiBvcHRpb25hbCB0YXJnZXQgbWF0cml4IHRvIHN0b3JlIHRoZSB0cmFuc2Zvcm1hdGlvbi4gSWYgbm90IHByb3ZpZGVkLCBpdCB3aWxsIGNyZWF0ZSBhIG5ldyBpbnN0YW5jZS5cblx0ICogQHJldHVybiBUaGUgdHJhbnNmb3JtYXRpb24gbWF0cml4IG9mIHRoZSBwb3NlLlxuXHQgKi9cblx0cHVibGljIHRvTWF0cml4M0QodGFyZ2V0Ok1hdHJpeDNEID0gbnVsbCk6TWF0cml4M0Rcblx0e1xuXHRcdGlmICh0YXJnZXQgPT0gbnVsbClcblx0XHRcdHRhcmdldCA9IG5ldyBNYXRyaXgzRCgpO1xuXG5cdFx0dGhpcy5vcmllbnRhdGlvbi50b01hdHJpeDNEKHRhcmdldCk7XG5cdFx0dGFyZ2V0LmFwcGVuZFRyYW5zbGF0aW9uKHRoaXMudHJhbnNsYXRpb24ueCwgdGhpcy50cmFuc2xhdGlvbi55LCB0aGlzLnRyYW5zbGF0aW9uLnopO1xuXHRcdHJldHVybiB0YXJnZXQ7XG5cdH1cblxuXHQvKipcblx0ICogQ29waWVzIHRoZSB0cmFuc2Zvcm1hdGlvbiBkYXRhIGZyb20gYSBzb3VyY2UgcG9zZSBvYmplY3QgaW50byB0aGUgZXhpc3RpbmcgcG9zZSBvYmplY3QuXG5cdCAqXG5cdCAqIEBwYXJhbSBwb3NlIFRoZSBzb3VyY2UgcG9zZSB0byBjb3B5IGZyb20uXG5cdCAqL1xuXHRwdWJsaWMgY29weUZyb20ocG9zZTpKb2ludFBvc2UpXG5cdHtcblx0XHR2YXIgb3I6UXVhdGVybmlvbiA9IHBvc2Uub3JpZW50YXRpb247XG5cdFx0dmFyIHRyOlZlY3RvcjNEID0gcG9zZS50cmFuc2xhdGlvbjtcblx0XHR0aGlzLm9yaWVudGF0aW9uLnggPSBvci54O1xuXHRcdHRoaXMub3JpZW50YXRpb24ueSA9IG9yLnk7XG5cdFx0dGhpcy5vcmllbnRhdGlvbi56ID0gb3Iuejtcblx0XHR0aGlzLm9yaWVudGF0aW9uLncgPSBvci53O1xuXHRcdHRoaXMudHJhbnNsYXRpb24ueCA9IHRyLng7XG5cdFx0dGhpcy50cmFuc2xhdGlvbi55ID0gdHIueTtcblx0XHR0aGlzLnRyYW5zbGF0aW9uLnogPSB0ci56O1xuXHR9XG59XG5cbmV4cG9ydCA9IEpvaW50UG9zZTsiXX0=
\ No newline at end of file
diff --git a/lib/animators/data/JointPose.ts b/lib/animators/data/JointPose.ts
new file mode 100644
index 000000000..2d25bf3e1
--- /dev/null
+++ b/lib/animators/data/JointPose.ts
@@ -0,0 +1,70 @@
+import Matrix3D = require("awayjs-core/lib/core/geom/Matrix3D");
+import Quaternion = require("awayjs-core/lib/core/geom/Quaternion");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+/**
+ * Contains transformation data for a skeleton joint, used for skeleton animation.
+ *
+ * @see away.animation.Skeleton
+ * @see away.animation.SkeletonJoint
+ *
+ * todo: support (uniform) scale
+ */
+class JointPose
+{
+ /**
+ * The name of the joint to which the pose is associated
+ */
+ public name:string; // intention is that this should be used only at load time, not in the main loop
+
+ /**
+ * The rotation of the pose stored as a quaternion
+ */
+ public orientation:Quaternion = new Quaternion();
+
+ /**
+ * The translation of the pose
+ */
+ public translation:Vector3D = new Vector3D();
+
+ constructor()
+ {
+
+ }
+
+ /**
+ * Converts the transformation to a Matrix3D representation.
+ *
+ * @param target An optional target matrix to store the transformation. If not provided, it will create a new instance.
+ * @return The transformation matrix of the pose.
+ */
+ public toMatrix3D(target:Matrix3D = null):Matrix3D
+ {
+ if (target == null)
+ target = new Matrix3D();
+
+ this.orientation.toMatrix3D(target);
+ target.appendTranslation(this.translation.x, this.translation.y, this.translation.z);
+ return target;
+ }
+
+ /**
+ * Copies the transformation data from a source pose object into the existing pose object.
+ *
+ * @param pose The source pose to copy from.
+ */
+ public copyFrom(pose:JointPose)
+ {
+ var or:Quaternion = pose.orientation;
+ var tr:Vector3D = pose.translation;
+ this.orientation.x = or.x;
+ this.orientation.y = or.y;
+ this.orientation.z = or.z;
+ this.orientation.w = or.w;
+ this.translation.x = tr.x;
+ this.translation.y = tr.y;
+ this.translation.z = tr.z;
+ }
+}
+
+export = JointPose;
\ No newline at end of file
diff --git a/lib/animators/data/ParticleAnimationData.js b/lib/animators/data/ParticleAnimationData.js
new file mode 100755
index 000000000..cceceeab9
--- /dev/null
+++ b/lib/animators/data/ParticleAnimationData.js
@@ -0,0 +1,18 @@
+/**
+ * ...
+ */
+var ParticleAnimationData = (function () {
+ function ParticleAnimationData(index /*uint*/, startTime, duration, delay, particle) {
+ this.index = index;
+ this.startTime = startTime;
+ this.totalTime = duration + delay;
+ this.duration = duration;
+ this.delay = delay;
+ this.startVertexIndex = particle.startVertexIndex;
+ this.numVertices = particle.numVertices;
+ }
+ return ParticleAnimationData;
+})();
+module.exports = ParticleAnimationData;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9kYXRhL3BhcnRpY2xlYW5pbWF0aW9uZGF0YS50cyJdLCJuYW1lcyI6WyJQYXJ0aWNsZUFuaW1hdGlvbkRhdGEiLCJQYXJ0aWNsZUFuaW1hdGlvbkRhdGEuY29uc3RydWN0b3IiXSwibWFwcGluZ3MiOiJBQUVBLEFBR0E7O0dBREc7SUFDRyxxQkFBcUI7SUFVMUJBLFNBVktBLHFCQUFxQkEsQ0FVZEEsS0FBS0EsQ0FBUUEsUUFBREEsQUFBU0EsRUFBRUEsU0FBZ0JBLEVBQUVBLFFBQWVBLEVBQUVBLEtBQVlBLEVBQUVBLFFBQXFCQTtRQUV4R0MsSUFBSUEsQ0FBQ0EsS0FBS0EsR0FBR0EsS0FBS0EsQ0FBQ0E7UUFDbkJBLElBQUlBLENBQUNBLFNBQVNBLEdBQUdBLFNBQVNBLENBQUNBO1FBQzNCQSxJQUFJQSxDQUFDQSxTQUFTQSxHQUFHQSxRQUFRQSxHQUFHQSxLQUFLQSxDQUFDQTtRQUNsQ0EsSUFBSUEsQ0FBQ0EsUUFBUUEsR0FBR0EsUUFBUUEsQ0FBQ0E7UUFDekJBLElBQUlBLENBQUNBLEtBQUtBLEdBQUdBLEtBQUtBLENBQUNBO1FBQ25CQSxJQUFJQSxDQUFDQSxnQkFBZ0JBLEdBQUdBLFFBQVFBLENBQUNBLGdCQUFnQkEsQ0FBQ0E7UUFDbERBLElBQUlBLENBQUNBLFdBQVdBLEdBQUdBLFFBQVFBLENBQUNBLFdBQVdBLENBQUNBO0lBQ3pDQSxDQUFDQTtJQUNGRCw0QkFBQ0E7QUFBREEsQ0FwQkEsQUFvQkNBLElBQUE7QUFFRCxBQUErQixpQkFBdEIscUJBQXFCLENBQUMiLCJmaWxlIjoiYW5pbWF0b3JzL2RhdGEvUGFydGljbGVBbmltYXRpb25EYXRhLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2JiYXRlbWFuL1dlYnN0b3JtUHJvamVjdHMvYXdheWpzLXJlbmRlcmVyZ2wvIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFBhcnRpY2xlRGF0YVx0XHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvZGF0YS9QYXJ0aWNsZURhdGFcIik7XG5cbi8qKlxuICogLi4uXG4gKi9cbmNsYXNzIFBhcnRpY2xlQW5pbWF0aW9uRGF0YVxue1xuXHRwdWJsaWMgaW5kZXg6bnVtYmVyIC8qdWludCovO1xuXHRwdWJsaWMgc3RhcnRUaW1lOm51bWJlcjtcblx0cHVibGljIHRvdGFsVGltZTpudW1iZXI7XG5cdHB1YmxpYyBkdXJhdGlvbjpudW1iZXI7XG5cdHB1YmxpYyBkZWxheTpudW1iZXI7XG5cdHB1YmxpYyBzdGFydFZlcnRleEluZGV4Om51bWJlciAvKnVpbnQqLztcblx0cHVibGljIG51bVZlcnRpY2VzOm51bWJlciAvKnVpbnQqLztcblxuXHRjb25zdHJ1Y3RvcihpbmRleDpudW1iZXIgLyp1aW50Ki8sIHN0YXJ0VGltZTpudW1iZXIsIGR1cmF0aW9uOm51bWJlciwgZGVsYXk6bnVtYmVyLCBwYXJ0aWNsZTpQYXJ0aWNsZURhdGEpXG5cdHtcblx0XHR0aGlzLmluZGV4ID0gaW5kZXg7XG5cdFx0dGhpcy5zdGFydFRpbWUgPSBzdGFydFRpbWU7XG5cdFx0dGhpcy50b3RhbFRpbWUgPSBkdXJhdGlvbiArIGRlbGF5O1xuXHRcdHRoaXMuZHVyYXRpb24gPSBkdXJhdGlvbjtcblx0XHR0aGlzLmRlbGF5ID0gZGVsYXk7XG5cdFx0dGhpcy5zdGFydFZlcnRleEluZGV4ID0gcGFydGljbGUuc3RhcnRWZXJ0ZXhJbmRleDtcblx0XHR0aGlzLm51bVZlcnRpY2VzID0gcGFydGljbGUubnVtVmVydGljZXM7XG5cdH1cbn1cblxuZXhwb3J0ID0gUGFydGljbGVBbmltYXRpb25EYXRhOyJdfQ==
\ No newline at end of file
diff --git a/lib/animators/data/ParticleAnimationData.ts b/lib/animators/data/ParticleAnimationData.ts
new file mode 100644
index 000000000..c18940adb
--- /dev/null
+++ b/lib/animators/data/ParticleAnimationData.ts
@@ -0,0 +1,28 @@
+import ParticleData = require("awayjs-renderergl/lib/animators/data/ParticleData");
+
+/**
+ * ...
+ */
+class ParticleAnimationData
+{
+ public index:number /*uint*/;
+ public startTime:number;
+ public totalTime:number;
+ public duration:number;
+ public delay:number;
+ public startVertexIndex:number /*uint*/;
+ public numVertices:number /*uint*/;
+
+ constructor(index:number /*uint*/, startTime:number, duration:number, delay:number, particle:ParticleData)
+ {
+ this.index = index;
+ this.startTime = startTime;
+ this.totalTime = duration + delay;
+ this.duration = duration;
+ this.delay = delay;
+ this.startVertexIndex = particle.startVertexIndex;
+ this.numVertices = particle.numVertices;
+ }
+}
+
+export = ParticleAnimationData;
\ No newline at end of file
diff --git a/lib/animators/data/ParticleData.js b/lib/animators/data/ParticleData.js
new file mode 100755
index 000000000..c4eee1032
--- /dev/null
+++ b/lib/animators/data/ParticleData.js
@@ -0,0 +1,8 @@
+var ParticleData = (function () {
+ function ParticleData() {
+ }
+ return ParticleData;
+})();
+module.exports = ParticleData;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9kYXRhL3BhcnRpY2xlZGF0YS50cyJdLCJuYW1lcyI6WyJQYXJ0aWNsZURhdGEiLCJQYXJ0aWNsZURhdGEuY29uc3RydWN0b3IiXSwibWFwcGluZ3MiOiJBQUVBLElBQU0sWUFBWTtJQUFsQkEsU0FBTUEsWUFBWUE7SUFNbEJDLENBQUNBO0lBQURELG1CQUFDQTtBQUFEQSxDQU5BLEFBTUNBLElBQUE7QUFFRCxBQUFxQixpQkFBWixZQUFZLENBQUEiLCJmaWxlIjoiYW5pbWF0b3JzL2RhdGEvUGFydGljbGVEYXRhLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2JiYXRlbWFuL1dlYnN0b3JtUHJvamVjdHMvYXdheWpzLXJlbmRlcmVyZ2wvIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFRyaWFuZ2xlU3ViR2VvbWV0cnlcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1jb3JlL2xpYi9jb3JlL2Jhc2UvVHJpYW5nbGVTdWJHZW9tZXRyeVwiKTtcblxuY2xhc3MgUGFydGljbGVEYXRhXG57XG5cdHB1YmxpYyBwYXJ0aWNsZUluZGV4Om51bWJlciAvKnVpbnQqLztcblx0cHVibGljIG51bVZlcnRpY2VzOm51bWJlciAvKnVpbnQqLztcblx0cHVibGljIHN0YXJ0VmVydGV4SW5kZXg6bnVtYmVyIC8qdWludCovO1xuXHRwdWJsaWMgc3ViR2VvbWV0cnk6VHJpYW5nbGVTdWJHZW9tZXRyeTtcbn1cblxuZXhwb3J0ID0gUGFydGljbGVEYXRhIl19
\ No newline at end of file
diff --git a/lib/animators/data/ParticleData.ts b/lib/animators/data/ParticleData.ts
new file mode 100644
index 000000000..5ec3c84b1
--- /dev/null
+++ b/lib/animators/data/ParticleData.ts
@@ -0,0 +1,11 @@
+import TriangleSubGeometry = require("awayjs-core/lib/core/base/TriangleSubGeometry");
+
+class ParticleData
+{
+ public particleIndex:number /*uint*/;
+ public numVertices:number /*uint*/;
+ public startVertexIndex:number /*uint*/;
+ public subGeometry:TriangleSubGeometry;
+}
+
+export = ParticleData
\ No newline at end of file
diff --git a/lib/animators/data/ParticleProperties.js b/lib/animators/data/ParticleProperties.js
new file mode 100755
index 000000000..8a516840a
--- /dev/null
+++ b/lib/animators/data/ParticleProperties.js
@@ -0,0 +1,12 @@
+/**
+ * Dynamic class for holding the local properties of a particle, used for processing the static properties
+ * of particles in the particle animation set before beginning upload to the GPU.
+ */
+var ParticleProperties = (function () {
+ function ParticleProperties() {
+ }
+ return ParticleProperties;
+})();
+module.exports = ParticleProperties;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9kYXRhL3BhcnRpY2xlcHJvcGVydGllcy50cyJdLCJuYW1lcyI6WyJQYXJ0aWNsZVByb3BlcnRpZXMiLCJQYXJ0aWNsZVByb3BlcnRpZXMuY29uc3RydWN0b3IiXSwibWFwcGluZ3MiOiJBQUFBLEFBSUE7OztHQURHO0lBQ0csa0JBQWtCO0lBQXhCQSxTQUFNQSxrQkFBa0JBO0lBOEJ4QkMsQ0FBQ0E7SUFBREQseUJBQUNBO0FBQURBLENBOUJBLEFBOEJDQSxJQUFBO0FBRUQsQUFBNEIsaUJBQW5CLGtCQUFrQixDQUFDIiwiZmlsZSI6ImFuaW1hdG9ycy9kYXRhL1BhcnRpY2xlUHJvcGVydGllcy5qcyIsInNvdXJjZVJvb3QiOiIvVXNlcnMvcm9iYmF0ZW1hbi9XZWJzdG9ybVByb2plY3RzL2F3YXlqcy1yZW5kZXJlcmdsLyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRHluYW1pYyBjbGFzcyBmb3IgaG9sZGluZyB0aGUgbG9jYWwgcHJvcGVydGllcyBvZiBhIHBhcnRpY2xlLCB1c2VkIGZvciBwcm9jZXNzaW5nIHRoZSBzdGF0aWMgcHJvcGVydGllc1xuICogb2YgcGFydGljbGVzIGluIHRoZSBwYXJ0aWNsZSBhbmltYXRpb24gc2V0IGJlZm9yZSBiZWdpbm5pbmcgdXBsb2FkIHRvIHRoZSBHUFUuXG4gKi9cbmNsYXNzIFBhcnRpY2xlUHJvcGVydGllc1xue1xuXHQvKipcblx0ICogVGhlIGluZGV4IG9mIHRoZSBjdXJyZW50IHBhcnRpY2xlIGJlaW5nIHNldC5cblx0ICovXG5cdHB1YmxpYyBpbmRleDpudW1iZXIgLyp1aW50Ki87XG5cblx0LyoqXG5cdCAqIFRoZSB0b3RhbCBudW1iZXIgb2YgcGFydGljbGVzIGJlaW5nIHByb2Nlc3NlZCBieSB0aGUgcGFydGljbGUgYW5pbWF0aW9uIHNldC5cblx0ICovXG5cdHB1YmxpYyB0b3RhbDpudW1iZXIgLyp1aW50Ki87XG5cblx0LyoqXG5cdCAqIFRoZSBzdGFydCB0aW1lIG9mIHRoZSBwYXJ0aWNsZS5cblx0ICovXG5cdHB1YmxpYyBzdGFydFRpbWU6bnVtYmVyO1xuXG5cdC8qKlxuXHQgKiBUaGUgZHVyYXRpb24gb2YgdGhlIHBhcnRpY2xlLCBhbiBvcHRpb25hbCB2YWx1ZSB1c2VkIHdoZW4gdGhlIHBhcnRpY2xlIGFuaWFtdGlvbiBzZXQgc2V0dGluZ3MgZm9yIDxjb2RlPnVzZUR1cmF0aW9uPC9jb2RlPiBhcmUgZW5hYmxlZCBpbiB0aGUgY29uc3RydWN0b3IuXG5cdCAqXG5cdCAqIEBzZWUgYXdheS5hbmltYXRvcnMuUGFydGljbGVBbmltYXRpb25TZXRcblx0ICovXG5cdHB1YmxpYyBkdXJhdGlvbjpudW1iZXI7XG5cblx0LyoqXG5cdCAqIFRoZSBkZWxheSBiZXR3ZWVuIGN5Y2xlcyBvZiB0aGUgcGFydGljbGUsIGFuIG9wdGlvbmFsIHZhbHVlIHVzZWQgd2hlbiB0aGUgcGFydGljbGUgYW5pYW10aW9uIHNldCBzZXR0aW5ncyBmb3IgPGNvZGU+dXNlTG9vcGluZzwvY29kZT4gYW5kICA8Y29kZT51c2VEZWxheTwvY29kZT4gYXJlIGVuYWJsZWQgaW4gdGhlIGNvbnN0cnVjdG9yLlxuXHQgKlxuXHQgKiBAc2VlIGF3YXkuYW5pbWF0b3JzLlBhcnRpY2xlQW5pbWF0aW9uU2V0XG5cdCAqL1xuXHRwdWJsaWMgZGVsYXk6bnVtYmVyO1xufVxuXG5leHBvcnQgPSBQYXJ0aWNsZVByb3BlcnRpZXM7Il19
\ No newline at end of file
diff --git a/lib/animators/data/ParticleProperties.ts b/lib/animators/data/ParticleProperties.ts
new file mode 100644
index 000000000..3da259b93
--- /dev/null
+++ b/lib/animators/data/ParticleProperties.ts
@@ -0,0 +1,37 @@
+/**
+ * Dynamic class for holding the local properties of a particle, used for processing the static properties
+ * of particles in the particle animation set before beginning upload to the GPU.
+ */
+class ParticleProperties
+{
+ /**
+ * The index of the current particle being set.
+ */
+ public index:number /*uint*/;
+
+ /**
+ * The total number of particles being processed by the particle animation set.
+ */
+ public total:number /*uint*/;
+
+ /**
+ * The start time of the particle.
+ */
+ public startTime:number;
+
+ /**
+ * The duration of the particle, an optional value used when the particle aniamtion set settings for useDuration
are enabled in the constructor.
+ *
+ * @see away.animators.ParticleAnimationSet
+ */
+ public duration:number;
+
+ /**
+ * The delay between cycles of the particle, an optional value used when the particle aniamtion set settings for useLooping
and useDelay
are enabled in the constructor.
+ *
+ * @see away.animators.ParticleAnimationSet
+ */
+ public delay:number;
+}
+
+export = ParticleProperties;
\ No newline at end of file
diff --git a/lib/animators/data/ParticlePropertiesMode.js b/lib/animators/data/ParticlePropertiesMode.js
new file mode 100755
index 000000000..dba8dcbdd
--- /dev/null
+++ b/lib/animators/data/ParticlePropertiesMode.js
@@ -0,0 +1,23 @@
+/**
+ * Options for setting the properties mode of a particle animation node.
+ */
+var ParticlePropertiesMode = (function () {
+ function ParticlePropertiesMode() {
+ }
+ /**
+ * Mode that defines the particle node as acting on global properties (ie. the properties set in the node constructor or the corresponding animation state).
+ */
+ ParticlePropertiesMode.GLOBAL = 0;
+ /**
+ * Mode that defines the particle node as acting on local static properties (ie. the properties of particles set in the initialising on the animation set).
+ */
+ ParticlePropertiesMode.LOCAL_STATIC = 1;
+ /**
+ * Mode that defines the particle node as acting on local dynamic properties (ie. the properties of the particles set in the corresponding animation state).
+ */
+ ParticlePropertiesMode.LOCAL_DYNAMIC = 2;
+ return ParticlePropertiesMode;
+})();
+module.exports = ParticlePropertiesMode;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9kYXRhL3BhcnRpY2xlcHJvcGVydGllc21vZGUudHMiXSwibmFtZXMiOlsiUGFydGljbGVQcm9wZXJ0aWVzTW9kZSIsIlBhcnRpY2xlUHJvcGVydGllc01vZGUuY29uc3RydWN0b3IiXSwibWFwcGluZ3MiOiJBQUFBLEFBR0E7O0dBREc7SUFDRyxzQkFBc0I7SUFBNUJBLFNBQU1BLHNCQUFzQkE7SUFnQjVCQyxDQUFDQTtJQWRBRDs7T0FFR0E7SUFDV0EsNkJBQU1BLEdBQW1CQSxDQUFDQSxDQUFDQTtJQUV6Q0E7O09BRUdBO0lBQ1dBLG1DQUFZQSxHQUFtQkEsQ0FBQ0EsQ0FBQ0E7SUFFL0NBOztPQUVHQTtJQUNXQSxvQ0FBYUEsR0FBbUJBLENBQUNBLENBQUNBO0lBQ2pEQSw2QkFBQ0E7QUFBREEsQ0FoQkEsQUFnQkNBLElBQUE7QUFFRCxBQUFnQyxpQkFBdkIsc0JBQXNCLENBQUMiLCJmaWxlIjoiYW5pbWF0b3JzL2RhdGEvUGFydGljbGVQcm9wZXJ0aWVzTW9kZS5qcyIsInNvdXJjZVJvb3QiOiIvVXNlcnMvcm9iYmF0ZW1hbi9XZWJzdG9ybVByb2plY3RzL2F3YXlqcy1yZW5kZXJlcmdsLyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogT3B0aW9ucyBmb3Igc2V0dGluZyB0aGUgcHJvcGVydGllcyBtb2RlIG9mIGEgcGFydGljbGUgYW5pbWF0aW9uIG5vZGUuXG4gKi9cbmNsYXNzIFBhcnRpY2xlUHJvcGVydGllc01vZGVcbntcblx0LyoqXG5cdCAqIE1vZGUgdGhhdCBkZWZpbmVzIHRoZSBwYXJ0aWNsZSBub2RlIGFzIGFjdGluZyBvbiBnbG9iYWwgcHJvcGVydGllcyAoaWUuIHRoZSBwcm9wZXJ0aWVzIHNldCBpbiB0aGUgbm9kZSBjb25zdHJ1Y3RvciBvciB0aGUgY29ycmVzcG9uZGluZyBhbmltYXRpb24gc3RhdGUpLlxuXHQgKi9cblx0cHVibGljIHN0YXRpYyBHTE9CQUw6bnVtYmVyIC8qdWludCovID0gMDtcblxuXHQvKipcblx0ICogTW9kZSB0aGF0IGRlZmluZXMgdGhlIHBhcnRpY2xlIG5vZGUgYXMgYWN0aW5nIG9uIGxvY2FsIHN0YXRpYyBwcm9wZXJ0aWVzIChpZS4gdGhlIHByb3BlcnRpZXMgb2YgcGFydGljbGVzIHNldCBpbiB0aGUgaW5pdGlhbGlzaW5nIG9uIHRoZSBhbmltYXRpb24gc2V0KS5cblx0ICovXG5cdHB1YmxpYyBzdGF0aWMgTE9DQUxfU1RBVElDOm51bWJlciAvKnVpbnQqLyA9IDE7XG5cblx0LyoqXG5cdCAqIE1vZGUgdGhhdCBkZWZpbmVzIHRoZSBwYXJ0aWNsZSBub2RlIGFzIGFjdGluZyBvbiBsb2NhbCBkeW5hbWljIHByb3BlcnRpZXMgKGllLiB0aGUgcHJvcGVydGllcyBvZiB0aGUgcGFydGljbGVzIHNldCBpbiB0aGUgY29ycmVzcG9uZGluZyBhbmltYXRpb24gc3RhdGUpLlxuXHQgKi9cblx0cHVibGljIHN0YXRpYyBMT0NBTF9EWU5BTUlDOm51bWJlciAvKnVpbnQqLyA9IDI7XG59XG5cbmV4cG9ydCA9IFBhcnRpY2xlUHJvcGVydGllc01vZGU7Il19
\ No newline at end of file
diff --git a/lib/animators/data/ParticlePropertiesMode.ts b/lib/animators/data/ParticlePropertiesMode.ts
new file mode 100644
index 000000000..a623bc964
--- /dev/null
+++ b/lib/animators/data/ParticlePropertiesMode.ts
@@ -0,0 +1,22 @@
+/**
+ * Options for setting the properties mode of a particle animation node.
+ */
+class ParticlePropertiesMode
+{
+ /**
+ * Mode that defines the particle node as acting on global properties (ie. the properties set in the node constructor or the corresponding animation state).
+ */
+ public static GLOBAL:number /*uint*/ = 0;
+
+ /**
+ * Mode that defines the particle node as acting on local static properties (ie. the properties of particles set in the initialising on the animation set).
+ */
+ public static LOCAL_STATIC:number /*uint*/ = 1;
+
+ /**
+ * Mode that defines the particle node as acting on local dynamic properties (ie. the properties of the particles set in the corresponding animation state).
+ */
+ public static LOCAL_DYNAMIC:number /*uint*/ = 2;
+}
+
+export = ParticlePropertiesMode;
\ No newline at end of file
diff --git a/lib/animators/data/Skeleton.js b/lib/animators/data/Skeleton.js
new file mode 100755
index 000000000..e56e1d692
--- /dev/null
+++ b/lib/animators/data/Skeleton.js
@@ -0,0 +1,94 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var AssetType = require("awayjs-core/lib/core/library/AssetType");
+var NamedAssetBase = require("awayjs-core/lib/core/library/NamedAssetBase");
+/**
+ * A Skeleton object is a hierarchical grouping of joint objects that can be used for skeletal animation.
+ *
+ * @see away.animators.SkeletonJoint
+ */
+var Skeleton = (function (_super) {
+ __extends(Skeleton, _super);
+ /**
+ * Creates a new Skeleton
object
+ */
+ function Skeleton() {
+ _super.call(this);
+ // in the long run, it might be a better idea to not store Joint objects, but keep all data in Vectors, that we can upload easily?
+ this.joints = new Array();
+ }
+ Object.defineProperty(Skeleton.prototype, "numJoints", {
+ /**
+ * The total number of joints in the skeleton.
+ */
+ get: function () {
+ return this.joints.length;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * Returns the joint object in the skeleton with the given name, otherwise returns a null object.
+ *
+ * @param jointName The name of the joint object to be found.
+ * @return The joint object with the given name.
+ *
+ * @see #joints
+ */
+ Skeleton.prototype.jointFromName = function (jointName) {
+ var jointIndex = this.jointIndexFromName(jointName);
+ if (jointIndex != -1)
+ return this.joints[jointIndex];
+ else
+ return null;
+ };
+ /**
+ * Returns the joint index, given the joint name. -1 is returned if the joint name is not found.
+ *
+ * @param jointName The name of the joint object to be found.
+ * @return The index of the joint object in the joints Array
+ *
+ * @see #joints
+ */
+ Skeleton.prototype.jointIndexFromName = function (jointName) {
+ // this is implemented as a linear search, rather than a possibly
+ // more optimal method (Dictionary lookup, for example) because:
+ // a) it is assumed that it will be called once for each joint
+ // b) it is assumed that it will be called only during load, and not during main loop
+ // c) maintaining a dictionary (for safety) would dictate an interface to access SkeletonJoints,
+ // rather than direct array access. this would be sub-optimal.
+ var jointIndex /*int*/;
+ var joint;
+ for (var i /*int*/; i < this.joints.length; i++) {
+ joint = this.joints[i];
+ if (joint.name == jointName)
+ return jointIndex;
+ jointIndex++;
+ }
+ return -1;
+ };
+ /**
+ * @inheritDoc
+ */
+ Skeleton.prototype.dispose = function () {
+ this.joints.length = 0;
+ };
+ Object.defineProperty(Skeleton.prototype, "assetType", {
+ /**
+ * @inheritDoc
+ */
+ get: function () {
+ return AssetType.SKELETON;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ return Skeleton;
+})(NamedAssetBase);
+module.exports = Skeleton;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9kYXRhL3NrZWxldG9uLnRzIl0sIm5hbWVzIjpbIlNrZWxldG9uIiwiU2tlbGV0b24uY29uc3RydWN0b3IiLCJTa2VsZXRvbi5udW1Kb2ludHMiLCJTa2VsZXRvbi5qb2ludEZyb21OYW1lIiwiU2tlbGV0b24uam9pbnRJbmRleEZyb21OYW1lIiwiU2tlbGV0b24uZGlzcG9zZSIsIlNrZWxldG9uLmFzc2V0VHlwZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBRUEsSUFBTyxTQUFTLFdBQWdCLHdDQUF3QyxDQUFDLENBQUM7QUFFMUUsSUFBTyxjQUFjLFdBQWUsNkNBQTZDLENBQUMsQ0FBQztBQUVuRixBQUtBOzs7O0dBREc7SUFDRyxRQUFRO0lBQVNBLFVBQWpCQSxRQUFRQSxVQUF1QkE7SUFpQnBDQTs7T0FFR0E7SUFDSEEsU0FwQktBLFFBQVFBO1FBc0JaQyxpQkFBT0EsQ0FBQ0E7UUFFUkEsQUFDQUEsa0lBRGtJQTtRQUNsSUEsSUFBSUEsQ0FBQ0EsTUFBTUEsR0FBR0EsSUFBSUEsS0FBS0EsRUFBaUJBLENBQUNBO0lBQzFDQSxDQUFDQTtJQWRERCxzQkFBV0EsK0JBQVNBO1FBSHBCQTs7V0FFR0E7YUFDSEE7WUFFQ0UsTUFBTUEsQ0FBQ0EsSUFBSUEsQ0FBQ0EsTUFBTUEsQ0FBQ0EsTUFBTUEsQ0FBQ0E7UUFDM0JBLENBQUNBOzs7T0FBQUY7SUFhREE7Ozs7Ozs7T0FPR0E7SUFDSUEsZ0NBQWFBLEdBQXBCQSxVQUFxQkEsU0FBZ0JBO1FBRXBDRyxJQUFJQSxVQUFVQSxHQUFrQkEsSUFBSUEsQ0FBQ0Esa0JBQWtCQSxDQUFDQSxTQUFTQSxDQUFDQSxDQUFDQTtRQUNuRUEsRUFBRUEsQ0FBQ0EsQ0FBQ0EsVUFBVUEsSUFBSUEsQ0FBQ0EsQ0FBQ0EsQ0FBQ0E7WUFDcEJBLE1BQU1BLENBQUNBLElBQUlBLENBQUNBLE1BQU1BLENBQUNBLFVBQVVBLENBQUNBLENBQUNBO1FBQUNBLElBQUlBO1lBQ3BDQSxNQUFNQSxDQUFDQSxJQUFJQSxDQUFDQTtJQUNkQSxDQUFDQTtJQUVESDs7Ozs7OztPQU9HQTtJQUNJQSxxQ0FBa0JBLEdBQXpCQSxVQUEwQkEsU0FBZ0JBO1FBRXpDSSxBQU1BQSxpRUFOaUVBO1FBQ2pFQSxnRUFBZ0VBO1FBQ2hFQSw4REFBOERBO1FBQzlEQSxxRkFBcUZBO1FBQ3JGQSxnR0FBZ0dBO1FBQ2hHQSxrRUFBa0VBO1lBQzlEQSxVQUFVQSxDQUFRQSxPQUFEQSxBQUFRQSxDQUFDQTtRQUM5QkEsSUFBSUEsS0FBbUJBLENBQUNBO1FBQ3hCQSxHQUFHQSxDQUFDQSxDQUFDQSxHQUFHQSxDQUFDQSxDQUFDQSxDQUFRQSxPQUFEQSxBQUFRQSxFQUFFQSxDQUFDQSxHQUFHQSxJQUFJQSxDQUFDQSxNQUFNQSxDQUFDQSxNQUFNQSxFQUFFQSxDQUFDQSxFQUFFQSxFQUFFQSxDQUFDQTtZQUN4REEsS0FBS0EsR0FBR0EsSUFBSUEsQ0FBQ0EsTUFBTUEsQ0FBQ0EsQ0FBQ0EsQ0FBQ0EsQ0FBQ0E7WUFDdkJBLEVBQUVBLENBQUNBLENBQUNBLEtBQUtBLENBQUNBLElBQUlBLElBQUlBLFNBQVNBLENBQUNBO2dCQUMzQkEsTUFBTUEsQ0FBQ0EsVUFBVUEsQ0FBQ0E7WUFDbkJBLFVBQVVBLEVBQUVBLENBQUNBO1FBQ2RBLENBQUNBO1FBRURBLE1BQU1BLENBQUNBLENBQUNBLENBQUNBLENBQUNBO0lBQ1hBLENBQUNBO0lBRURKOztPQUVHQTtJQUNJQSwwQkFBT0EsR0FBZEE7UUFFQ0ssSUFBSUEsQ0FBQ0EsTUFBTUEsQ0FBQ0EsTUFBTUEsR0FBR0EsQ0FBQ0EsQ0FBQ0E7SUFDeEJBLENBQUNBO0lBS0RMLHNCQUFXQSwrQkFBU0E7UUFIcEJBOztXQUVHQTthQUNIQTtZQUVDTSxNQUFNQSxDQUFDQSxTQUFTQSxDQUFDQSxRQUFRQSxDQUFDQTtRQUMzQkEsQ0FBQ0E7OztPQUFBTjtJQUNGQSxlQUFDQTtBQUFEQSxDQXZGQSxBQXVGQ0EsRUF2RnNCLGNBQWMsRUF1RnBDO0FBRUQsQUFBa0IsaUJBQVQsUUFBUSxDQUFDIiwiZmlsZSI6ImFuaW1hdG9ycy9kYXRhL1NrZWxldG9uLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2JiYXRlbWFuL1dlYnN0b3JtUHJvamVjdHMvYXdheWpzLXJlbmRlcmVyZ2wvIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFNrZWxldG9uSm9pbnRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXJlbmRlcmVyZ2wvbGliL2FuaW1hdG9ycy9kYXRhL1NrZWxldG9uSm9pbnRcIik7XG5cbmltcG9ydCBBc3NldFR5cGVcdFx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvY29yZS9saWJyYXJ5L0Fzc2V0VHlwZVwiKTtcbmltcG9ydCBJQXNzZXRcdFx0XHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1jb3JlL2xpYi9jb3JlL2xpYnJhcnkvSUFzc2V0XCIpO1xuaW1wb3J0IE5hbWVkQXNzZXRCYXNlXHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1jb3JlL2xpYi9jb3JlL2xpYnJhcnkvTmFtZWRBc3NldEJhc2VcIik7XG5cbi8qKlxuICogQSBTa2VsZXRvbiBvYmplY3QgaXMgYSBoaWVyYXJjaGljYWwgZ3JvdXBpbmcgb2Ygam9pbnQgb2JqZWN0cyB0aGF0IGNhbiBiZSB1c2VkIGZvciBza2VsZXRhbCBhbmltYXRpb24uXG4gKlxuICogQHNlZSBhd2F5LmFuaW1hdG9ycy5Ta2VsZXRvbkpvaW50XG4gKi9cbmNsYXNzIFNrZWxldG9uIGV4dGVuZHMgTmFtZWRBc3NldEJhc2UgaW1wbGVtZW50cyBJQXNzZXRcbntcblx0LyoqXG5cdCAqIEEgZmxhdCBsaXN0IG9mIGpvaW50IG9iamVjdHMgdGhhdCBjb21wcmlzZSB0aGUgc2tlbGV0b24uIEV2ZXJ5IGpvaW50IGV4Y2VwdCBmb3IgdGhlIHJvb3QgaGFzIGEgcGFyZW50SW5kZXhcblx0ICogcHJvcGVydHkgdGhhdCBpcyBhbiBpbmRleCBpbnRvIHRoaXMgbGlzdC5cblx0ICogQSBjaGlsZCBqb2ludCBzaG91bGQgYWx3YXlzIGhhdmUgYSBoaWdoZXIgaW5kZXggdGhhbiBpdHMgcGFyZW50LlxuXHQgKi9cblx0cHVibGljIGpvaW50czpBcnJheTxTa2VsZXRvbkpvaW50PjtcblxuXHQvKipcblx0ICogVGhlIHRvdGFsIG51bWJlciBvZiBqb2ludHMgaW4gdGhlIHNrZWxldG9uLlxuXHQgKi9cblx0cHVibGljIGdldCBudW1Kb2ludHMoKTpudW1iZXIgLyp1aW50Ki9cblx0e1xuXHRcdHJldHVybiB0aGlzLmpvaW50cy5sZW5ndGg7XG5cdH1cblxuXHQvKipcblx0ICogQ3JlYXRlcyBhIG5ldyA8Y29kZT5Ta2VsZXRvbjwvY29kZT4gb2JqZWN0XG5cdCAqL1xuXHRjb25zdHJ1Y3RvcigpXG5cdHtcblx0XHRzdXBlcigpO1xuXG5cdFx0Ly8gaW4gdGhlIGxvbmcgcnVuLCBpdCBtaWdodCBiZSBhIGJldHRlciBpZGVhIHRvIG5vdCBzdG9yZSBKb2ludCBvYmplY3RzLCBidXQga2VlcCBhbGwgZGF0YSBpbiBWZWN0b3JzLCB0aGF0IHdlIGNhbiB1cGxvYWQgZWFzaWx5P1xuXHRcdHRoaXMuam9pbnRzID0gbmV3IEFycmF5PFNrZWxldG9uSm9pbnQ+KCk7XG5cdH1cblxuXHQvKipcblx0ICogUmV0dXJucyB0aGUgam9pbnQgb2JqZWN0IGluIHRoZSBza2VsZXRvbiB3aXRoIHRoZSBnaXZlbiBuYW1lLCBvdGhlcndpc2UgcmV0dXJucyBhIG51bGwgb2JqZWN0LlxuXHQgKlxuXHQgKiBAcGFyYW0gam9pbnROYW1lIFRoZSBuYW1lIG9mIHRoZSBqb2ludCBvYmplY3QgdG8gYmUgZm91bmQuXG5cdCAqIEByZXR1cm4gVGhlIGpvaW50IG9iamVjdCB3aXRoIHRoZSBnaXZlbiBuYW1lLlxuXHQgKlxuXHQgKiBAc2VlICNqb2ludHNcblx0ICovXG5cdHB1YmxpYyBqb2ludEZyb21OYW1lKGpvaW50TmFtZTpzdHJpbmcpOlNrZWxldG9uSm9pbnRcblx0e1xuXHRcdHZhciBqb2ludEluZGV4Om51bWJlciAvKmludCovID0gdGhpcy5qb2ludEluZGV4RnJvbU5hbWUoam9pbnROYW1lKTtcblx0XHRpZiAoam9pbnRJbmRleCAhPSAtMSlcblx0XHRcdHJldHVybiB0aGlzLmpvaW50c1tqb2ludEluZGV4XTsgZWxzZVxuXHRcdFx0cmV0dXJuIG51bGw7XG5cdH1cblxuXHQvKipcblx0ICogUmV0dXJucyB0aGUgam9pbnQgaW5kZXgsIGdpdmVuIHRoZSBqb2ludCBuYW1lLiAtMSBpcyByZXR1cm5lZCBpZiB0aGUgam9pbnQgbmFtZSBpcyBub3QgZm91bmQuXG5cdCAqXG5cdCAqIEBwYXJhbSBqb2ludE5hbWUgVGhlIG5hbWUgb2YgdGhlIGpvaW50IG9iamVjdCB0byBiZSBmb3VuZC5cblx0ICogQHJldHVybiBUaGUgaW5kZXggb2YgdGhlIGpvaW50IG9iamVjdCBpbiB0aGUgam9pbnRzIEFycmF5XG5cdCAqXG5cdCAqIEBzZWUgI2pvaW50c1xuXHQgKi9cblx0cHVibGljIGpvaW50SW5kZXhGcm9tTmFtZShqb2ludE5hbWU6c3RyaW5nKTpudW1iZXIgLyppbnQqL1xuXHR7XG5cdFx0Ly8gdGhpcyBpcyBpbXBsZW1lbnRlZCBhcyBhIGxpbmVhciBzZWFyY2gsIHJhdGhlciB0aGFuIGEgcG9zc2libHlcblx0XHQvLyBtb3JlIG9wdGltYWwgbWV0aG9kIChEaWN0aW9uYXJ5IGxvb2t1cCwgZm9yIGV4YW1wbGUpIGJlY2F1c2U6XG5cdFx0Ly8gYSkgaXQgaXMgYXNzdW1lZCB0aGF0IGl0IHdpbGwgYmUgY2FsbGVkIG9uY2UgZm9yIGVhY2ggam9pbnRcblx0XHQvLyBiKSBpdCBpcyBhc3N1bWVkIHRoYXQgaXQgd2lsbCBiZSBjYWxsZWQgb25seSBkdXJpbmcgbG9hZCwgYW5kIG5vdCBkdXJpbmcgbWFpbiBsb29wXG5cdFx0Ly8gYykgbWFpbnRhaW5pbmcgYSBkaWN0aW9uYXJ5IChmb3Igc2FmZXR5KSB3b3VsZCBkaWN0YXRlIGFuIGludGVyZmFjZSB0byBhY2Nlc3MgU2tlbGV0b25Kb2ludHMsXG5cdFx0Ly8gICAgcmF0aGVyIHRoYW4gZGlyZWN0IGFycmF5IGFjY2Vzcy4gIHRoaXMgd291bGQgYmUgc3ViLW9wdGltYWwuXG5cdFx0dmFyIGpvaW50SW5kZXg6bnVtYmVyIC8qaW50Ki87XG5cdFx0dmFyIGpvaW50OlNrZWxldG9uSm9pbnQ7XG5cdFx0Zm9yICh2YXIgaTpudW1iZXIgLyppbnQqLzsgaSA8IHRoaXMuam9pbnRzLmxlbmd0aDsgaSsrKSB7XG5cdFx0XHRqb2ludCA9IHRoaXMuam9pbnRzW2ldO1xuXHRcdFx0aWYgKGpvaW50Lm5hbWUgPT0gam9pbnROYW1lKVxuXHRcdFx0XHRyZXR1cm4gam9pbnRJbmRleDtcblx0XHRcdGpvaW50SW5kZXgrKztcblx0XHR9XG5cblx0XHRyZXR1cm4gLTE7XG5cdH1cblxuXHQvKipcblx0ICogQGluaGVyaXREb2Ncblx0ICovXG5cdHB1YmxpYyBkaXNwb3NlKClcblx0e1xuXHRcdHRoaXMuam9pbnRzLmxlbmd0aCA9IDA7XG5cdH1cblxuXHQvKipcblx0ICogQGluaGVyaXREb2Ncblx0ICovXG5cdHB1YmxpYyBnZXQgYXNzZXRUeXBlKCk6c3RyaW5nXG5cdHtcblx0XHRyZXR1cm4gQXNzZXRUeXBlLlNLRUxFVE9OO1xuXHR9XG59XG5cbmV4cG9ydCA9IFNrZWxldG9uOyJdfQ==
\ No newline at end of file
diff --git a/lib/animators/data/Skeleton.ts b/lib/animators/data/Skeleton.ts
new file mode 100644
index 000000000..61bcfff38
--- /dev/null
+++ b/lib/animators/data/Skeleton.ts
@@ -0,0 +1,101 @@
+import SkeletonJoint = require("awayjs-renderergl/lib/animators/data/SkeletonJoint");
+
+import AssetType = require("awayjs-core/lib/core/library/AssetType");
+import IAsset = require("awayjs-core/lib/core/library/IAsset");
+import NamedAssetBase = require("awayjs-core/lib/core/library/NamedAssetBase");
+
+/**
+ * A Skeleton object is a hierarchical grouping of joint objects that can be used for skeletal animation.
+ *
+ * @see away.animators.SkeletonJoint
+ */
+class Skeleton extends NamedAssetBase implements IAsset
+{
+ /**
+ * A flat list of joint objects that comprise the skeleton. Every joint except for the root has a parentIndex
+ * property that is an index into this list.
+ * A child joint should always have a higher index than its parent.
+ */
+ public joints:Array;
+
+ /**
+ * The total number of joints in the skeleton.
+ */
+ public get numJoints():number /*uint*/
+ {
+ return this.joints.length;
+ }
+
+ /**
+ * Creates a new Skeleton
object
+ */
+ constructor()
+ {
+ super();
+
+ // in the long run, it might be a better idea to not store Joint objects, but keep all data in Vectors, that we can upload easily?
+ this.joints = new Array();
+ }
+
+ /**
+ * Returns the joint object in the skeleton with the given name, otherwise returns a null object.
+ *
+ * @param jointName The name of the joint object to be found.
+ * @return The joint object with the given name.
+ *
+ * @see #joints
+ */
+ public jointFromName(jointName:string):SkeletonJoint
+ {
+ var jointIndex:number /*int*/ = this.jointIndexFromName(jointName);
+ if (jointIndex != -1)
+ return this.joints[jointIndex]; else
+ return null;
+ }
+
+ /**
+ * Returns the joint index, given the joint name. -1 is returned if the joint name is not found.
+ *
+ * @param jointName The name of the joint object to be found.
+ * @return The index of the joint object in the joints Array
+ *
+ * @see #joints
+ */
+ public jointIndexFromName(jointName:string):number /*int*/
+ {
+ // this is implemented as a linear search, rather than a possibly
+ // more optimal method (Dictionary lookup, for example) because:
+ // a) it is assumed that it will be called once for each joint
+ // b) it is assumed that it will be called only during load, and not during main loop
+ // c) maintaining a dictionary (for safety) would dictate an interface to access SkeletonJoints,
+ // rather than direct array access. this would be sub-optimal.
+ var jointIndex:number /*int*/;
+ var joint:SkeletonJoint;
+ for (var i:number /*int*/; i < this.joints.length; i++) {
+ joint = this.joints[i];
+ if (joint.name == jointName)
+ return jointIndex;
+ jointIndex++;
+ }
+
+ return -1;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public dispose()
+ {
+ this.joints.length = 0;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public get assetType():string
+ {
+ return AssetType.SKELETON;
+ }
+}
+
+export = Skeleton;
\ No newline at end of file
diff --git a/lib/animators/data/SkeletonJoint.js b/lib/animators/data/SkeletonJoint.js
new file mode 100755
index 000000000..8e0c24473
--- /dev/null
+++ b/lib/animators/data/SkeletonJoint.js
@@ -0,0 +1,22 @@
+/**
+ * A value obect representing a single joint in a skeleton object.
+ *
+ * @see away.animators.Skeleton
+ */
+var SkeletonJoint = (function () {
+ /**
+ * Creates a new SkeletonJoint
object
+ */
+ function SkeletonJoint() {
+ /**
+ * The index of the parent joint in the skeleton's joints vector.
+ *
+ * @see away.animators.Skeleton#joints
+ */
+ this.parentIndex = -1;
+ }
+ return SkeletonJoint;
+})();
+module.exports = SkeletonJoint;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9kYXRhL3NrZWxldG9uam9pbnQudHMiXSwibmFtZXMiOlsiU2tlbGV0b25Kb2ludCIsIlNrZWxldG9uSm9pbnQuY29uc3RydWN0b3IiXSwibWFwcGluZ3MiOiJBQUFBLEFBS0E7Ozs7R0FERztJQUNHLGFBQWE7SUFtQmxCQTs7T0FFR0E7SUFDSEEsU0F0QktBLGFBQWFBO1FBRWxCQzs7OztXQUlHQTtRQUNJQSxnQkFBV0EsR0FBa0JBLENBQUNBLENBQUNBLENBQUNBO0lBaUJ2Q0EsQ0FBQ0E7SUFDRkQsb0JBQUNBO0FBQURBLENBekJBLEFBeUJDQSxJQUFBO0FBRUQsQUFBdUIsaUJBQWQsYUFBYSxDQUFDIiwiZmlsZSI6ImFuaW1hdG9ycy9kYXRhL1NrZWxldG9uSm9pbnQuanMiLCJzb3VyY2VSb290IjoiL1VzZXJzL3JvYmJhdGVtYW4vV2Vic3Rvcm1Qcm9qZWN0cy9hd2F5anMtcmVuZGVyZXJnbC8iLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEEgdmFsdWUgb2JlY3QgcmVwcmVzZW50aW5nIGEgc2luZ2xlIGpvaW50IGluIGEgc2tlbGV0b24gb2JqZWN0LlxuICpcbiAqIEBzZWUgYXdheS5hbmltYXRvcnMuU2tlbGV0b25cbiAqL1xuY2xhc3MgU2tlbGV0b25Kb2ludFxue1xuXHQvKipcblx0ICogVGhlIGluZGV4IG9mIHRoZSBwYXJlbnQgam9pbnQgaW4gdGhlIHNrZWxldG9uJ3Mgam9pbnRzIHZlY3Rvci5cblx0ICpcblx0ICogQHNlZSBhd2F5LmFuaW1hdG9ycy5Ta2VsZXRvbiNqb2ludHNcblx0ICovXG5cdHB1YmxpYyBwYXJlbnRJbmRleDpudW1iZXIgLyppbnQqLyA9IC0xO1xuXG5cdC8qKlxuXHQgKiBUaGUgbmFtZSBvZiB0aGUgam9pbnRcblx0ICovXG5cdHB1YmxpYyBuYW1lOnN0cmluZzsgLy8gaW50ZW50aW9uIGlzIHRoYXQgdGhpcyBzaG91bGQgYmUgdXNlZCBvbmx5IGF0IGxvYWQgdGltZSwgbm90IGluIHRoZSBtYWluIGxvb3BcblxuXHQvKipcblx0ICogVGhlIGludmVyc2UgYmluZCBwb3NlIG1hdHJpeCwgYXMgcmF3IGRhdGEsIHVzZWQgdG8gdHJhbnNmb3JtIHZlcnRpY2VzIHRvIGJpbmQgam9pbnQgc3BhY2UgaW4gcHJlcGFyYXRpb24gZm9yIHRyYW5zZm9ybWF0aW9uIHVzaW5nIHRoZSBqb2ludCBtYXRyaXguXG5cdCAqL1xuXHRwdWJsaWMgaW52ZXJzZUJpbmRQb3NlOkFycmF5PG51bWJlcj47XG5cblx0LyoqXG5cdCAqIENyZWF0ZXMgYSBuZXcgPGNvZGU+U2tlbGV0b25Kb2ludDwvY29kZT4gb2JqZWN0XG5cdCAqL1xuXHRjb25zdHJ1Y3RvcigpXG5cdHtcblx0fVxufVxuXG5leHBvcnQgPSBTa2VsZXRvbkpvaW50OyJdfQ==
\ No newline at end of file
diff --git a/lib/animators/data/SkeletonJoint.ts b/lib/animators/data/SkeletonJoint.ts
new file mode 100644
index 000000000..a02a3dc8c
--- /dev/null
+++ b/lib/animators/data/SkeletonJoint.ts
@@ -0,0 +1,33 @@
+/**
+ * A value obect representing a single joint in a skeleton object.
+ *
+ * @see away.animators.Skeleton
+ */
+class SkeletonJoint
+{
+ /**
+ * The index of the parent joint in the skeleton's joints vector.
+ *
+ * @see away.animators.Skeleton#joints
+ */
+ public parentIndex:number /*int*/ = -1;
+
+ /**
+ * The name of the joint
+ */
+ public name:string; // intention is that this should be used only at load time, not in the main loop
+
+ /**
+ * The inverse bind pose matrix, as raw data, used to transform vertices to bind joint space in preparation for transformation using the joint matrix.
+ */
+ public inverseBindPose:Array;
+
+ /**
+ * Creates a new SkeletonJoint
object
+ */
+ constructor()
+ {
+ }
+}
+
+export = SkeletonJoint;
\ No newline at end of file
diff --git a/lib/animators/data/SkeletonPose.js b/lib/animators/data/SkeletonPose.js
new file mode 100755
index 000000000..73f924129
--- /dev/null
+++ b/lib/animators/data/SkeletonPose.js
@@ -0,0 +1,113 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var JointPose = require("awayjs-renderergl/lib/animators/data/JointPose");
+var AssetType = require("awayjs-core/lib/core/library/AssetType");
+var NamedAssetBase = require("awayjs-core/lib/core/library/NamedAssetBase");
+/**
+ * A collection of pose objects, determining the pose for an entire skeleton.
+ * The jointPoses
vector object corresponds to a skeleton's joints
vector object, however, there is no
+ * reference to a skeleton's instance, since several skeletons can be influenced by the same pose (eg: animation
+ * clips are added to any animator with a valid skeleton)
+ *
+ * @see away.animators.Skeleton
+ * @see away.animators.JointPose
+ */
+var SkeletonPose = (function (_super) {
+ __extends(SkeletonPose, _super);
+ /**
+ * Creates a new SkeletonPose
object.
+ */
+ function SkeletonPose() {
+ _super.call(this);
+ this.jointPoses = new Array();
+ }
+ Object.defineProperty(SkeletonPose.prototype, "numJointPoses", {
+ /**
+ * The total number of joint poses in the skeleton pose.
+ */
+ get: function () {
+ return this.jointPoses.length;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(SkeletonPose.prototype, "assetType", {
+ /**
+ * @inheritDoc
+ */
+ get: function () {
+ return AssetType.SKELETON_POSE;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * Returns the joint pose object with the given joint name, otherwise returns a null object.
+ *
+ * @param jointName The name of the joint object whose pose is to be found.
+ * @return The pose object with the given joint name.
+ */
+ SkeletonPose.prototype.jointPoseFromName = function (jointName) {
+ var jointPoseIndex = this.jointPoseIndexFromName(jointName);
+ if (jointPoseIndex != -1)
+ return this.jointPoses[jointPoseIndex];
+ else
+ return null;
+ };
+ /**
+ * Returns the pose index, given the joint name. -1 is returned if the joint name is not found in the pose.
+ *
+ * @param The name of the joint object whose pose is to be found.
+ * @return The index of the pose object in the jointPoses Array
+ *
+ * @see #jointPoses
+ */
+ SkeletonPose.prototype.jointPoseIndexFromName = function (jointName) {
+ // this is implemented as a linear search, rather than a possibly
+ // more optimal method (Dictionary lookup, for example) because:
+ // a) it is assumed that it will be called once for each joint
+ // b) it is assumed that it will be called only during load, and not during main loop
+ // c) maintaining a dictionary (for safety) would dictate an interface to access JointPoses,
+ // rather than direct array access. this would be sub-optimal.
+ var jointPoseIndex /*int*/;
+ var jointPose;
+ for (var i /*uint*/; i < this.jointPoses.length; i++) {
+ jointPose = this.jointPoses[i];
+ if (jointPose.name == jointName)
+ return jointPoseIndex;
+ jointPoseIndex++;
+ }
+ return -1;
+ };
+ /**
+ * Creates a copy of the SkeletonPose
object, with a dulpicate of its component joint poses.
+ *
+ * @return SkeletonPose
+ */
+ SkeletonPose.prototype.clone = function () {
+ var clone = new SkeletonPose();
+ var numJointPoses = this.jointPoses.length;
+ for (var i = 0; i < numJointPoses; i++) {
+ var cloneJointPose = new JointPose();
+ var thisJointPose = this.jointPoses[i];
+ cloneJointPose.name = thisJointPose.name;
+ cloneJointPose.copyFrom(thisJointPose);
+ clone.jointPoses[i] = cloneJointPose;
+ }
+ return clone;
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonPose.prototype.dispose = function () {
+ this.jointPoses.length = 0;
+ };
+ return SkeletonPose;
+})(NamedAssetBase);
+module.exports = SkeletonPose;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/data/skeletonpose.ts"],"names":["SkeletonPose","SkeletonPose.constructor","SkeletonPose.numJointPoses","SkeletonPose.assetType","SkeletonPose.jointPoseFromName","SkeletonPose.jointPoseIndexFromName","SkeletonPose.clone","SkeletonPose.dispose"],"mappings":"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","file":"animators/data/SkeletonPose.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import JointPose\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/JointPose\");\n\nimport AssetType\t\t\t\t\t\t= require(\"awayjs-core/lib/core/library/AssetType\");\nimport IAsset\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/library/IAsset\");\nimport NamedAssetBase\t\t\t\t\t= require(\"awayjs-core/lib/core/library/NamedAssetBase\");\n\n/**\n * A collection of pose objects, determining the pose for an entire skeleton.\n * The <code>jointPoses</code> vector object corresponds to a skeleton's <code>joints</code> vector object, however, there is no\n * reference to a skeleton's instance, since several skeletons can be influenced by the same pose (eg: animation\n * clips are added to any animator with a valid skeleton)\n *\n * @see away.animators.Skeleton\n * @see away.animators.JointPose\n */\nclass SkeletonPose extends NamedAssetBase implements IAsset\n{\n\t/**\n\t * A flat list of pose objects that comprise the skeleton pose. The pose indices correspond to the target skeleton's joint indices.\n\t *\n\t * @see away.animators.Skeleton#joints\n\t */\n\tpublic jointPoses:Array<JointPose>;\n\n\t/**\n\t * The total number of joint poses in the skeleton pose.\n\t */\n\tpublic get numJointPoses():number /*uint*/\n\t{\n\t\treturn this.jointPoses.length;\n\t}\n\n\t/**\n\t * Creates a new <code>SkeletonPose</code> object.\n\t */\n\tconstructor()\n\t{\n\t\tsuper();\n\n\t\tthis.jointPoses = new Array<JointPose>();\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic get assetType():string\n\t{\n\t\treturn AssetType.SKELETON_POSE;\n\t}\n\n\t/**\n\t * Returns the joint pose object with the given joint name, otherwise returns a null object.\n\t *\n\t * @param jointName The name of the joint object whose pose is to be found.\n\t * @return The pose object with the given joint name.\n\t */\n\tpublic jointPoseFromName(jointName:string):JointPose\n\t{\n\t\tvar jointPoseIndex:number /*int*/ = this.jointPoseIndexFromName(jointName);\n\t\tif (jointPoseIndex != -1)\n\t\t\treturn this.jointPoses[jointPoseIndex]; else\n\t\t\treturn null;\n\t}\n\n\t/**\n\t * Returns the pose index, given the joint name. -1 is returned if the joint name is not found in the pose.\n\t *\n\t * @param The name of the joint object whose pose is to be found.\n\t * @return The index of the pose object in the jointPoses Array\n\t *\n\t * @see #jointPoses\n\t */\n\tpublic jointPoseIndexFromName(jointName:string):number /*int*/\n\t{\n\t\t// this is implemented as a linear search, rather than a possibly\n\t\t// more optimal method (Dictionary lookup, for example) because:\n\t\t// a) it is assumed that it will be called once for each joint\n\t\t// b) it is assumed that it will be called only during load, and not during main loop\n\t\t// c) maintaining a dictionary (for safety) would dictate an interface to access JointPoses,\n\t\t//    rather than direct array access.  this would be sub-optimal.\n\t\tvar jointPoseIndex:number /*int*/;\n\t\tvar jointPose:JointPose;\n\t\tfor (var i:number /*uint*/; i < this.jointPoses.length; i++) {\n\t\t\tjointPose = this.jointPoses[i];\n\t\t\tif (jointPose.name == jointName)\n\t\t\t\treturn jointPoseIndex;\n\t\t\tjointPoseIndex++;\n\t\t}\n\n\t\treturn -1;\n\t}\n\n\t/**\n\t * Creates a copy of the <code>SkeletonPose</code> object, with a dulpicate of its component joint poses.\n\t *\n\t * @return SkeletonPose\n\t */\n\tpublic clone():SkeletonPose\n\t{\n\t\tvar clone:SkeletonPose = new SkeletonPose();\n\t\tvar numJointPoses:number /*uint*/ = this.jointPoses.length;\n\t\tfor (var i:number /*uint*/ = 0; i < numJointPoses; i++) {\n\t\t\tvar cloneJointPose:JointPose = new JointPose();\n\t\t\tvar thisJointPose:JointPose = this.jointPoses[i];\n\t\t\tcloneJointPose.name = thisJointPose.name;\n\t\t\tcloneJointPose.copyFrom(thisJointPose);\n\t\t\tclone.jointPoses[i] = cloneJointPose;\n\t\t}\n\t\treturn clone;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic dispose()\n\t{\n\t\tthis.jointPoses.length = 0;\n\t}\n}\n\nexport = SkeletonPose;"]}
\ No newline at end of file
diff --git a/lib/animators/data/SkeletonPose.ts b/lib/animators/data/SkeletonPose.ts
new file mode 100644
index 000000000..3223a3d31
--- /dev/null
+++ b/lib/animators/data/SkeletonPose.ts
@@ -0,0 +1,121 @@
+import JointPose = require("awayjs-renderergl/lib/animators/data/JointPose");
+
+import AssetType = require("awayjs-core/lib/core/library/AssetType");
+import IAsset = require("awayjs-core/lib/core/library/IAsset");
+import NamedAssetBase = require("awayjs-core/lib/core/library/NamedAssetBase");
+
+/**
+ * A collection of pose objects, determining the pose for an entire skeleton.
+ * The jointPoses
vector object corresponds to a skeleton's joints
vector object, however, there is no
+ * reference to a skeleton's instance, since several skeletons can be influenced by the same pose (eg: animation
+ * clips are added to any animator with a valid skeleton)
+ *
+ * @see away.animators.Skeleton
+ * @see away.animators.JointPose
+ */
+class SkeletonPose extends NamedAssetBase implements IAsset
+{
+ /**
+ * A flat list of pose objects that comprise the skeleton pose. The pose indices correspond to the target skeleton's joint indices.
+ *
+ * @see away.animators.Skeleton#joints
+ */
+ public jointPoses:Array;
+
+ /**
+ * The total number of joint poses in the skeleton pose.
+ */
+ public get numJointPoses():number /*uint*/
+ {
+ return this.jointPoses.length;
+ }
+
+ /**
+ * Creates a new SkeletonPose
object.
+ */
+ constructor()
+ {
+ super();
+
+ this.jointPoses = new Array();
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public get assetType():string
+ {
+ return AssetType.SKELETON_POSE;
+ }
+
+ /**
+ * Returns the joint pose object with the given joint name, otherwise returns a null object.
+ *
+ * @param jointName The name of the joint object whose pose is to be found.
+ * @return The pose object with the given joint name.
+ */
+ public jointPoseFromName(jointName:string):JointPose
+ {
+ var jointPoseIndex:number /*int*/ = this.jointPoseIndexFromName(jointName);
+ if (jointPoseIndex != -1)
+ return this.jointPoses[jointPoseIndex]; else
+ return null;
+ }
+
+ /**
+ * Returns the pose index, given the joint name. -1 is returned if the joint name is not found in the pose.
+ *
+ * @param The name of the joint object whose pose is to be found.
+ * @return The index of the pose object in the jointPoses Array
+ *
+ * @see #jointPoses
+ */
+ public jointPoseIndexFromName(jointName:string):number /*int*/
+ {
+ // this is implemented as a linear search, rather than a possibly
+ // more optimal method (Dictionary lookup, for example) because:
+ // a) it is assumed that it will be called once for each joint
+ // b) it is assumed that it will be called only during load, and not during main loop
+ // c) maintaining a dictionary (for safety) would dictate an interface to access JointPoses,
+ // rather than direct array access. this would be sub-optimal.
+ var jointPoseIndex:number /*int*/;
+ var jointPose:JointPose;
+ for (var i:number /*uint*/; i < this.jointPoses.length; i++) {
+ jointPose = this.jointPoses[i];
+ if (jointPose.name == jointName)
+ return jointPoseIndex;
+ jointPoseIndex++;
+ }
+
+ return -1;
+ }
+
+ /**
+ * Creates a copy of the SkeletonPose
object, with a dulpicate of its component joint poses.
+ *
+ * @return SkeletonPose
+ */
+ public clone():SkeletonPose
+ {
+ var clone:SkeletonPose = new SkeletonPose();
+ var numJointPoses:number /*uint*/ = this.jointPoses.length;
+ for (var i:number /*uint*/ = 0; i < numJointPoses; i++) {
+ var cloneJointPose:JointPose = new JointPose();
+ var thisJointPose:JointPose = this.jointPoses[i];
+ cloneJointPose.name = thisJointPose.name;
+ cloneJointPose.copyFrom(thisJointPose);
+ clone.jointPoses[i] = cloneJointPose;
+ }
+ return clone;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public dispose()
+ {
+ this.jointPoses.length = 0;
+ }
+}
+
+export = SkeletonPose;
\ No newline at end of file
diff --git a/lib/animators/data/VertexAnimationMode.js b/lib/animators/data/VertexAnimationMode.js
new file mode 100755
index 000000000..c83fbda70
--- /dev/null
+++ b/lib/animators/data/VertexAnimationMode.js
@@ -0,0 +1,21 @@
+/**
+ * Options for setting the animation mode of a vertex animator object.
+ *
+ * @see away.animators.VertexAnimator
+ */
+var VertexAnimationMode = (function () {
+ function VertexAnimationMode() {
+ }
+ /**
+ * Animation mode that adds all outputs from active vertex animation state to form the current vertex animation pose.
+ */
+ VertexAnimationMode.ADDITIVE = "additive";
+ /**
+ * Animation mode that picks the output from a single vertex animation state to form the current vertex animation pose.
+ */
+ VertexAnimationMode.ABSOLUTE = "absolute";
+ return VertexAnimationMode;
+})();
+module.exports = VertexAnimationMode;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9kYXRhL3ZlcnRleGFuaW1hdGlvbm1vZGUudHMiXSwibmFtZXMiOlsiVmVydGV4QW5pbWF0aW9uTW9kZSIsIlZlcnRleEFuaW1hdGlvbk1vZGUuY29uc3RydWN0b3IiXSwibWFwcGluZ3MiOiJBQUFBLEFBS0E7Ozs7R0FERztJQUNHLG1CQUFtQjtJQUF6QkEsU0FBTUEsbUJBQW1CQTtJQVd6QkMsQ0FBQ0E7SUFUQUQ7O09BRUdBO0lBQ1dBLDRCQUFRQSxHQUFVQSxVQUFVQSxDQUFDQTtJQUUzQ0E7O09BRUdBO0lBQ1dBLDRCQUFRQSxHQUFVQSxVQUFVQSxDQUFDQTtJQUM1Q0EsMEJBQUNBO0FBQURBLENBWEEsQUFXQ0EsSUFBQTtBQUVELEFBQTZCLGlCQUFwQixtQkFBbUIsQ0FBQyIsImZpbGUiOiJhbmltYXRvcnMvZGF0YS9WZXJ0ZXhBbmltYXRpb25Nb2RlLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2JiYXRlbWFuL1dlYnN0b3JtUHJvamVjdHMvYXdheWpzLXJlbmRlcmVyZ2wvIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBPcHRpb25zIGZvciBzZXR0aW5nIHRoZSBhbmltYXRpb24gbW9kZSBvZiBhIHZlcnRleCBhbmltYXRvciBvYmplY3QuXG4gKlxuICogQHNlZSBhd2F5LmFuaW1hdG9ycy5WZXJ0ZXhBbmltYXRvclxuICovXG5jbGFzcyBWZXJ0ZXhBbmltYXRpb25Nb2RlXG57XG5cdC8qKlxuXHQgKiBBbmltYXRpb24gbW9kZSB0aGF0IGFkZHMgYWxsIG91dHB1dHMgZnJvbSBhY3RpdmUgdmVydGV4IGFuaW1hdGlvbiBzdGF0ZSB0byBmb3JtIHRoZSBjdXJyZW50IHZlcnRleCBhbmltYXRpb24gcG9zZS5cblx0ICovXG5cdHB1YmxpYyBzdGF0aWMgQURESVRJVkU6c3RyaW5nID0gXCJhZGRpdGl2ZVwiO1xuXG5cdC8qKlxuXHQgKiBBbmltYXRpb24gbW9kZSB0aGF0IHBpY2tzIHRoZSBvdXRwdXQgZnJvbSBhIHNpbmdsZSB2ZXJ0ZXggYW5pbWF0aW9uIHN0YXRlIHRvIGZvcm0gdGhlIGN1cnJlbnQgdmVydGV4IGFuaW1hdGlvbiBwb3NlLlxuXHQgKi9cblx0cHVibGljIHN0YXRpYyBBQlNPTFVURTpzdHJpbmcgPSBcImFic29sdXRlXCI7XG59XG5cbmV4cG9ydCA9IFZlcnRleEFuaW1hdGlvbk1vZGU7Il19
\ No newline at end of file
diff --git a/lib/animators/data/VertexAnimationMode.ts b/lib/animators/data/VertexAnimationMode.ts
new file mode 100644
index 000000000..c188e10a3
--- /dev/null
+++ b/lib/animators/data/VertexAnimationMode.ts
@@ -0,0 +1,19 @@
+/**
+ * Options for setting the animation mode of a vertex animator object.
+ *
+ * @see away.animators.VertexAnimator
+ */
+class VertexAnimationMode
+{
+ /**
+ * Animation mode that adds all outputs from active vertex animation state to form the current vertex animation pose.
+ */
+ public static ADDITIVE:string = "additive";
+
+ /**
+ * Animation mode that picks the output from a single vertex animation state to form the current vertex animation pose.
+ */
+ public static ABSOLUTE:string = "absolute";
+}
+
+export = VertexAnimationMode;
\ No newline at end of file
diff --git a/lib/animators/nodes/AnimationClipNodeBase.js b/lib/animators/nodes/AnimationClipNodeBase.js
new file mode 100755
index 000000000..279920229
--- /dev/null
+++ b/lib/animators/nodes/AnimationClipNodeBase.js
@@ -0,0 +1,116 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var AnimationNodeBase = require("awayjs-core/lib/animators/nodes/AnimationNodeBase");
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+/**
+ * Provides an abstract base class for nodes with time-based animation data in an animation blend tree.
+ */
+var AnimationClipNodeBase = (function (_super) {
+ __extends(AnimationClipNodeBase, _super);
+ /**
+ * Creates a new AnimationClipNodeBase
object.
+ */
+ function AnimationClipNodeBase() {
+ _super.call(this);
+ this._pLooping = true;
+ this._pTotalDuration = 0;
+ this._pStitchDirty = true;
+ this._pStitchFinalFrame = false;
+ this._pNumFrames = 0;
+ this._pDurations = new Array();
+ /*uint*/
+ this._pTotalDelta = new Vector3D();
+ this.fixedFrameRate = true;
+ }
+ Object.defineProperty(AnimationClipNodeBase.prototype, "looping", {
+ /**
+ * Determines whether the contents of the animation node have looping characteristics enabled.
+ */
+ get: function () {
+ return this._pLooping;
+ },
+ set: function (value) {
+ if (this._pLooping == value)
+ return;
+ this._pLooping = value;
+ this._pStitchDirty = true;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(AnimationClipNodeBase.prototype, "stitchFinalFrame", {
+ /**
+ * Defines if looping content blends the final frame of animation data with the first (true) or works on the
+ * assumption that both first and last frames are identical (false). Defaults to false.
+ */
+ get: function () {
+ return this._pStitchFinalFrame;
+ },
+ set: function (value) {
+ if (this._pStitchFinalFrame == value)
+ return;
+ this._pStitchFinalFrame = value;
+ this._pStitchDirty = true;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(AnimationClipNodeBase.prototype, "totalDuration", {
+ get: function () {
+ if (this._pStitchDirty)
+ this._pUpdateStitch();
+ return this._pTotalDuration;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(AnimationClipNodeBase.prototype, "totalDelta", {
+ get: function () {
+ if (this._pStitchDirty)
+ this._pUpdateStitch();
+ return this._pTotalDelta;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(AnimationClipNodeBase.prototype, "lastFrame", {
+ get: function () {
+ if (this._pStitchDirty)
+ this._pUpdateStitch();
+ return this._pLastFrame;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(AnimationClipNodeBase.prototype, "durations", {
+ /**
+ * Returns a vector of time values representing the duration (in milliseconds) of each animation frame in the clip.
+ */
+ get: function () {
+ return this._pDurations;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * Updates the node's final frame stitch state.
+ *
+ * @see #stitchFinalFrame
+ */
+ AnimationClipNodeBase.prototype._pUpdateStitch = function () {
+ this._pStitchDirty = false;
+ this._pLastFrame = (this._pStitchFinalFrame) ? this._pNumFrames : this._pNumFrames - 1;
+ this._pTotalDuration = 0;
+ this._pTotalDelta.x = 0;
+ this._pTotalDelta.y = 0;
+ this._pTotalDelta.z = 0;
+ };
+ return AnimationClipNodeBase;
+})(AnimationNodeBase);
+module.exports = AnimationClipNodeBase;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9ub2Rlcy9hbmltYXRpb25jbGlwbm9kZWJhc2UudHMiXSwibmFtZXMiOlsiQW5pbWF0aW9uQ2xpcE5vZGVCYXNlIiwiQW5pbWF0aW9uQ2xpcE5vZGVCYXNlLmNvbnN0cnVjdG9yIiwiQW5pbWF0aW9uQ2xpcE5vZGVCYXNlLmxvb3BpbmciLCJBbmltYXRpb25DbGlwTm9kZUJhc2Uuc3RpdGNoRmluYWxGcmFtZSIsIkFuaW1hdGlvbkNsaXBOb2RlQmFzZS50b3RhbER1cmF0aW9uIiwiQW5pbWF0aW9uQ2xpcE5vZGVCYXNlLnRvdGFsRGVsdGEiLCJBbmltYXRpb25DbGlwTm9kZUJhc2UubGFzdEZyYW1lIiwiQW5pbWF0aW9uQ2xpcE5vZGVCYXNlLmR1cmF0aW9ucyIsIkFuaW1hdGlvbkNsaXBOb2RlQmFzZS5fcFVwZGF0ZVN0aXRjaCJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsSUFBTyxpQkFBaUIsV0FBYyxtREFBbUQsQ0FBQyxDQUFDO0FBQzNGLElBQU8sUUFBUSxXQUFpQixvQ0FBb0MsQ0FBQyxDQUFDO0FBRXRFLEFBR0E7O0dBREc7SUFDRyxxQkFBcUI7SUFBU0EsVUFBOUJBLHFCQUFxQkEsVUFBMEJBO0lBcUZwREE7O09BRUdBO0lBQ0hBLFNBeEZLQSxxQkFBcUJBO1FBMEZ6QkMsaUJBQU9BLENBQUNBO1FBeEZGQSxjQUFTQSxHQUFXQSxJQUFJQSxDQUFDQTtRQUN6QkEsb0JBQWVBLEdBQW1CQSxDQUFDQSxDQUFDQTtRQUdwQ0Esa0JBQWFBLEdBQVdBLElBQUlBLENBQUNBO1FBQzdCQSx1QkFBa0JBLEdBQVdBLEtBQUtBLENBQUNBO1FBQ25DQSxnQkFBV0EsR0FBbUJBLENBQUNBLENBQUNBO1FBRWhDQSxnQkFBV0EsR0FBaUJBLElBQUlBLEtBQUtBLEVBQVVBLENBQUNBO1FBQ3ZEQSxRQUFRQTtRQUNEQSxpQkFBWUEsR0FBWUEsSUFBSUEsUUFBUUEsRUFBRUEsQ0FBQ0E7UUFFdkNBLG1CQUFjQSxHQUFXQSxJQUFJQSxDQUFDQTtJQTZF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Q2xpcE5vZGVCYXNlLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2JiYXRlbWFuL1dlYnN0b3JtUHJvamVjdHMvYXdheWpzLXJlbmRlcmVyZ2wvIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEFuaW1hdGlvbk5vZGVCYXNlXHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvYW5pbWF0b3JzL25vZGVzL0FuaW1hdGlvbk5vZGVCYXNlXCIpO1xuaW1wb3J0IFZlY3RvcjNEXHRcdFx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvY29yZS9nZW9tL1ZlY3RvcjNEXCIpO1xuXG4vKipcbiAqIFByb3ZpZGVzIGFuIGFic3RyYWN0IGJhc2UgY2xhc3MgZm9yIG5vZGVzIHdpdGggdGltZS1iYXNlZCBhbmltYXRpb24gZGF0YSBpbiBhbiBhbmltYXRpb24gYmxlbmQgdHJlZS5cbiAqL1xuY2xhc3MgQW5pbWF0aW9uQ2xpcE5vZGVCYXNlIGV4dGVuZHMgQW5pbWF0aW9uTm9kZUJhc2Vcbntcblx0cHVibGljIF9wTG9vcGluZzpib29sZWFuID0gdHJ1ZTtcblx0cHVibGljIF9wVG90YWxEdXJhdGlvbjpudW1iZXIgLyp1aW50Ki8gPSAwO1xuXHRwdWJsaWMgX3BMYXN0RnJhbWU6bnVtYmVyIC8qdWludCovO1xuXG5cdHB1YmxpYyBfcFN0aXRjaERpcnR5OmJvb2xlYW4gPSB0cnVlO1xuXHRwdWJsaWMgX3BTdGl0Y2hGaW5hbEZyYW1lOmJvb2xlYW4gPSBmYWxzZTtcblx0cHVibGljIF9wTnVtRnJhbWVzOm51bWJlciAvKnVpbnQqLyA9IDA7XG5cblx0cHVibGljIF9wRHVyYXRpb25zOkFycmF5PG51bWJlcj4gPSBuZXcgQXJyYXk8bnVtYmVyPigpO1xuXHQvKnVpbnQqL1xuXHRwdWJsaWMgX3BUb3RhbERlbHRhOlZlY3RvcjNEID0gbmV3IFZlY3RvcjNEKCk7XG5cblx0cHVibGljIGZpeGVkRnJhbWVSYXRlOmJvb2xlYW4gPSB0cnVlO1xuXG5cdC8qKlxuXHQgKiBEZXRlcm1pbmVzIHdoZXRoZXIgdGhlIGNvbnRlbnRzIG9mIHRoZSBhbmltYXRpb24gbm9kZSBoYXZlIGxvb3BpbmcgY2hhcmFjdGVyaXN0aWNzIGVuYWJsZWQuXG5cdCAqL1xuXHRwdWJsaWMgZ2V0IGxvb3BpbmcoKTpib29sZWFuXG5cdHtcblx0XHRyZXR1cm4gdGhpcy5fcExvb3Bpbmc7XG5cdH1cblxuXHRwdWJsaWMgc2V0IGxvb3BpbmcodmFsdWU6Ym9vbGVhbilcblx0e1xuXHRcdGlmICh0aGlzLl9wTG9vcGluZyA9PSB2YWx1ZSlcblx0XHRcdHJldHVybjtcblxuXHRcdHRoaXMuX3BMb29waW5nID0gdmFsdWU7XG5cblx0XHR0aGlzLl9wU3RpdGNoRGlydHkgPSB0cnVlO1xuXHR9XG5cblx0LyoqXG5cdCAqIERlZmluZXMgaWYgbG9vcGluZyBjb250ZW50IGJsZW5kcyB0aGUgZmluYWwgZnJhbWUgb2YgYW5pbWF0aW9uIGRhdGEgd2l0aCB0aGUgZmlyc3QgKHRydWUpIG9yIHdvcmtzIG9uIHRoZVxuXHQgKiBhc3N1bXB0aW9uIHRoYXQgYm90aCBmaXJzdCBhbmQgbGFzdCBmcmFtZXMgYXJlIGlkZW50aWNhbCAoZmFsc2UpLiBEZWZhdWx0cyB0byBmYWxzZS5cblx0ICovXG5cdHB1YmxpYyBnZXQgc3RpdGNoRmluYWxGcmFtZSgpOmJvb2xlYW5cblx0e1xuXHRcdHJldHVybiB0aGlzLl9wU3RpdGNoRmluYWxGcmFtZTtcblx0fVxuXG5cdHB1YmxpYyBzZXQgc3RpdGNoRmluYWxGcmFtZSh2YWx1ZTpib29sZWFuKVxuXHR7XG5cdFx0aWYgKHRoaXMuX3BTdGl0Y2hGaW5hbEZyYW1lID09IHZhbHVlKVxuXHRcdFx0cmV0dXJuO1xuXG5cdFx0dGhpcy5fcFN0aXRjaEZpbmFsRnJhbWUgPSB2YWx1ZTtcblxuXHRcdHRoaXMuX3BTdGl0Y2hEaXJ0eSA9IHRydWU7XG5cdH1cblxuXHRwdWJsaWMgZ2V0IHRvdGFsRHVyYXRpb24oKTpudW1iZXIgLyp1aW50Ki9cblx0e1xuXHRcdGlmICh0aGlzLl9wU3RpdGNoRGlydHkpXG5cdFx0XHR0aGlzLl9wVXBkYXRlU3RpdGNoKCk7XG5cblx0XHRyZXR1cm4gdGhpcy5fcFRvdGFsRHVyYXRpb247XG5cdH1cblxuXHRwdWJsaWMgZ2V0IHRvdGFsRGVsdGEoKTpWZWN0b3IzRFxuXHR7XG5cdFx0aWYgKHRoaXMuX3BTdGl0Y2hEaXJ0eSlcblx0XHRcdHRoaXMuX3BVcGRhdGVTdGl0Y2goKTtcblxuXHRcdHJldHVybiB0aGlzLl9wVG90YWxEZWx0YTtcblx0fVxuXG5cdHB1YmxpYyBnZXQgbGFzdEZyYW1lKCk6bnVtYmVyIC8qdWludCovXG5cdHtcblx0XHRpZiAodGhpcy5fcFN0aXRjaERpcnR5KVxuXHRcdFx0dGhpcy5fcFVwZGF0ZVN0aXRjaCgpO1xuXG5cdFx0cmV0dXJuIHRoaXMuX3BMYXN0RnJhbWU7XG5cdH1cblxuXHQvKipcblx0ICogUmV0dXJucyBhIHZlY3RvciBvZiB0aW1lIHZhbHVlcyByZXByZXNlbnRpbmcgdGhlIGR1cmF0aW9uIChpbiBtaWxsaXNlY29uZHMpIG9mIGVhY2ggYW5pbWF0aW9uIGZyYW1lIGluIHRoZSBjbGlwLlxuXHQgKi9cblx0cHVibGljIGdldCBkdXJhdGlvbnMoKTpBcnJheTxudW1iZXI+IC8qdWludCovXG5cdHtcblx0XHRyZXR1cm4gdGhpcy5fcER1cmF0aW9ucztcblx0fVxuXG5cdC8qKlxuXHQgKiBDcmVhdGVzIGEgbmV3IDxjb2RlPkFuaW1hdGlvbkNsaXBOb2RlQmFzZTwvY29kZT4gb2JqZWN0LlxuXHQgKi9cblx0Y29uc3RydWN0b3IoKVxuXHR7XG5cdFx0c3VwZXIoKTtcblx0fVxuXG5cdC8qKlxuXHQgKiBVcGRhdGVzIHRoZSBub2RlJ3MgZmluYWwgZnJhbWUgc3RpdGNoIHN0YXRlLlxuXHQgKlxuXHQgKiBAc2VlICNzdGl0Y2hGaW5hbEZyYW1lXG5cdCAqL1xuXHRwdWJsaWMgX3BVcGRhdGVTdGl0Y2goKVxuXHR7XG5cdFx0dGhpcy5fcFN0aXRjaERpcnR5ID0gZmFsc2U7XG5cblx0XHR0aGlzLl9wTGFzdEZyYW1lID0gKHRoaXMuX3BTdGl0Y2hGaW5hbEZyYW1lKT8gdGhpcy5fcE51bUZyYW1lcyA6IHRoaXMuX3BOdW1GcmFtZXMgLSAxO1xuXG5cdFx0dGhpcy5fcFRvdGFsRHVyYXRpb24gPSAwO1xuXHRcdHRoaXMuX3BUb3RhbERlbHRhLnggPSAwO1xuXHRcdHRoaXMuX3BUb3RhbERlbHRhLnkgPSAwO1xuXHRcdHRoaXMuX3BUb3RhbERlbHRhLnogPSAwO1xuXHR9XG59XG5cbmV4cG9ydCA9IEFuaW1hdGlvbkNsaXBOb2RlQmFzZTsiXX0=
\ No newline at end of file
diff --git a/lib/animators/nodes/AnimationClipNodeBase.ts b/lib/animators/nodes/AnimationClipNodeBase.ts
new file mode 100644
index 000000000..a6933746a
--- /dev/null
+++ b/lib/animators/nodes/AnimationClipNodeBase.ts
@@ -0,0 +1,118 @@
+import AnimationNodeBase = require("awayjs-core/lib/animators/nodes/AnimationNodeBase");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+/**
+ * Provides an abstract base class for nodes with time-based animation data in an animation blend tree.
+ */
+class AnimationClipNodeBase extends AnimationNodeBase
+{
+ public _pLooping:boolean = true;
+ public _pTotalDuration:number /*uint*/ = 0;
+ public _pLastFrame:number /*uint*/;
+
+ public _pStitchDirty:boolean = true;
+ public _pStitchFinalFrame:boolean = false;
+ public _pNumFrames:number /*uint*/ = 0;
+
+ public _pDurations:Array = new Array();
+ /*uint*/
+ public _pTotalDelta:Vector3D = new Vector3D();
+
+ public fixedFrameRate:boolean = true;
+
+ /**
+ * Determines whether the contents of the animation node have looping characteristics enabled.
+ */
+ public get looping():boolean
+ {
+ return this._pLooping;
+ }
+
+ public set looping(value:boolean)
+ {
+ if (this._pLooping == value)
+ return;
+
+ this._pLooping = value;
+
+ this._pStitchDirty = true;
+ }
+
+ /**
+ * Defines if looping content blends the final frame of animation data with the first (true) or works on the
+ * assumption that both first and last frames are identical (false). Defaults to false.
+ */
+ public get stitchFinalFrame():boolean
+ {
+ return this._pStitchFinalFrame;
+ }
+
+ public set stitchFinalFrame(value:boolean)
+ {
+ if (this._pStitchFinalFrame == value)
+ return;
+
+ this._pStitchFinalFrame = value;
+
+ this._pStitchDirty = true;
+ }
+
+ public get totalDuration():number /*uint*/
+ {
+ if (this._pStitchDirty)
+ this._pUpdateStitch();
+
+ return this._pTotalDuration;
+ }
+
+ public get totalDelta():Vector3D
+ {
+ if (this._pStitchDirty)
+ this._pUpdateStitch();
+
+ return this._pTotalDelta;
+ }
+
+ public get lastFrame():number /*uint*/
+ {
+ if (this._pStitchDirty)
+ this._pUpdateStitch();
+
+ return this._pLastFrame;
+ }
+
+ /**
+ * Returns a vector of time values representing the duration (in milliseconds) of each animation frame in the clip.
+ */
+ public get durations():Array /*uint*/
+ {
+ return this._pDurations;
+ }
+
+ /**
+ * Creates a new AnimationClipNodeBase
object.
+ */
+ constructor()
+ {
+ super();
+ }
+
+ /**
+ * Updates the node's final frame stitch state.
+ *
+ * @see #stitchFinalFrame
+ */
+ public _pUpdateStitch()
+ {
+ this._pStitchDirty = false;
+
+ this._pLastFrame = (this._pStitchFinalFrame)? this._pNumFrames : this._pNumFrames - 1;
+
+ this._pTotalDuration = 0;
+ this._pTotalDelta.x = 0;
+ this._pTotalDelta.y = 0;
+ this._pTotalDelta.z = 0;
+ }
+}
+
+export = AnimationClipNodeBase;
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleAccelerationNode.js b/lib/animators/nodes/ParticleAccelerationNode.js
new file mode 100755
index 000000000..5b4c1adfd
--- /dev/null
+++ b/lib/animators/nodes/ParticleAccelerationNode.js
@@ -0,0 +1,73 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+var ParticleAccelerationState = require("awayjs-renderergl/lib/animators/states/ParticleAccelerationState");
+/**
+ * A particle animation node used to apply a constant acceleration vector to the motion of a particle.
+ */
+var ParticleAccelerationNode = (function (_super) {
+ __extends(ParticleAccelerationNode, _super);
+ /**
+ * Creates a new ParticleAccelerationNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] acceleration Defines the default acceleration vector of the node, used when in global mode.
+ */
+ function ParticleAccelerationNode(mode /*uint*/, acceleration) {
+ if (acceleration === void 0) { acceleration = null; }
+ _super.call(this, "ParticleAcceleration", mode, 3);
+ this._pStateClass = ParticleAccelerationState;
+ this._acceleration = acceleration || new Vector3D();
+ }
+ /**
+ * @inheritDoc
+ */
+ ParticleAccelerationNode.prototype.pGetAGALVertexCode = function (shaderObject, animationRegisterCache) {
+ var accelerationValue = (this._pMode == ParticlePropertiesMode.GLOBAL) ? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleAccelerationState.ACCELERATION_INDEX, accelerationValue.index);
+ var temp = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp, 1);
+ var code = "mul " + temp + "," + animationRegisterCache.vertexTime + "," + accelerationValue + "\n";
+ if (animationRegisterCache.needVelocity) {
+ var temp2 = animationRegisterCache.getFreeVertexVectorTemp();
+ code += "mul " + temp2 + "," + temp + "," + animationRegisterCache.vertexTwoConst + "\n";
+ code += "add " + animationRegisterCache.velocityTarget + ".xyz," + temp2 + ".xyz," + animationRegisterCache.velocityTarget + ".xyz\n";
+ }
+ animationRegisterCache.removeVertexTempUsage(temp);
+ code += "mul " + temp + "," + temp + "," + animationRegisterCache.vertexTime + "\n";
+ code += "add " + animationRegisterCache.positionTarget + ".xyz," + temp + "," + animationRegisterCache.positionTarget + ".xyz\n";
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleAccelerationNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleAccelerationNode.prototype._iGeneratePropertyOfOneParticle = function (param) {
+ var tempAcceleration = param[ParticleAccelerationNode.ACCELERATION_VECTOR3D];
+ if (!tempAcceleration)
+ throw new Error("there is no " + ParticleAccelerationNode.ACCELERATION_VECTOR3D + " in param!");
+ this._pOneData[0] = tempAcceleration.x / 2;
+ this._pOneData[1] = tempAcceleration.y / 2;
+ this._pOneData[2] = tempAcceleration.z / 2;
+ };
+ /**
+ * Reference for acceleration node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
object representing the direction of acceleration on the particle.
+ */
+ ParticleAccelerationNode.ACCELERATION_VECTOR3D = "AccelerationVector3D";
+ return ParticleAccelerationNode;
+})(ParticleNodeBase);
+module.exports = ParticleAccelerationNode;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/nodes/particleaccelerationnode.ts"],"names":["ParticleAccelerationNode","ParticleAccelerationNode.constructor","ParticleAccelerationNode.pGetAGALVertexCode","ParticleAccelerationNode.getAnimationState","ParticleAccelerationNode._iGeneratePropertyOfOneParticle"],"mappings":"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","file":"animators/nodes/ParticleAccelerationNode.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\n\nimport ParticleProperties\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleProperties\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleNodeBase\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleNodeBase\");\nimport ParticleAccelerationState\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleAccelerationState\");\n\n/**\n * A particle animation node used to apply a constant acceleration vector to the motion of a particle.\n */\nclass ParticleAccelerationNode extends ParticleNodeBase\n{\n\t/** @private */\n\tpublic _acceleration:Vector3D;\n\n\t/**\n\t * Reference for acceleration node properties on a single particle (when in local property mode).\n\t * Expects a <code>Vector3D</code> object representing the direction of acceleration on the particle.\n\t */\n\tpublic static ACCELERATION_VECTOR3D:string = \"AccelerationVector3D\";\n\n\t/**\n\t * Creates a new <code>ParticleAccelerationNode</code>\n\t *\n\t * @param               mode            Defines whether the mode of operation acts on local properties of a particle or global properties of the node.\n\t * @param    [optional] acceleration    Defines the default acceleration vector of the node, used when in global mode.\n\t */\n\tconstructor(mode:number /*uint*/, acceleration:Vector3D = null)\n\t{\n\t\tsuper(\"ParticleAcceleration\", mode, 3);\n\n\t\tthis._pStateClass = ParticleAccelerationState;\n\n\t\tthis._acceleration = acceleration || new Vector3D();\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic pGetAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string\n\t{\n\t\tvar accelerationValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();\n\t\tanimationRegisterCache.setRegisterIndex(this, ParticleAccelerationState.ACCELERATION_INDEX, accelerationValue.index);\n\n\t\tvar temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\tanimationRegisterCache.addVertexTempUsages(temp, 1);\n\n\t\tvar code:string = \"mul \" + temp + \",\" + animationRegisterCache.vertexTime + \",\" + accelerationValue + \"\\n\";\n\n\t\tif (animationRegisterCache.needVelocity) {\n\t\t\tvar temp2:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\t\tcode += \"mul \" + temp2 + \",\" + temp + \",\" + animationRegisterCache.vertexTwoConst + \"\\n\";\n\t\t\tcode += \"add \" + animationRegisterCache.velocityTarget + \".xyz,\" + temp2 + \".xyz,\" + animationRegisterCache.velocityTarget + \".xyz\\n\";\n\t\t}\n\t\tanimationRegisterCache.removeVertexTempUsage(temp);\n\n\t\tcode += \"mul \" + temp + \",\" + temp + \",\" + animationRegisterCache.vertexTime + \"\\n\";\n\t\tcode += \"add \" + animationRegisterCache.positionTarget + \".xyz,\" + temp + \",\" + animationRegisterCache.positionTarget + \".xyz\\n\";\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAnimationState(animator:AnimatorBase):ParticleAccelerationState\n\t{\n\t\treturn <ParticleAccelerationState> animator.getAnimationState(this);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _iGeneratePropertyOfOneParticle(param:ParticleProperties)\n\t{\n\t\tvar tempAcceleration:Vector3D = param[ParticleAccelerationNode.ACCELERATION_VECTOR3D];\n\t\tif (!tempAcceleration)\n\t\t\tthrow new Error(\"there is no \" + ParticleAccelerationNode.ACCELERATION_VECTOR3D + \" in param!\");\n\n\t\tthis._pOneData[0] = tempAcceleration.x/2;\n\t\tthis._pOneData[1] = tempAcceleration.y/2;\n\t\tthis._pOneData[2] = tempAcceleration.z/2;\n\t}\n}\n\nexport = ParticleAccelerationNode;"]}
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleAccelerationNode.ts b/lib/animators/nodes/ParticleAccelerationNode.ts
new file mode 100644
index 000000000..06894ea4f
--- /dev/null
+++ b/lib/animators/nodes/ParticleAccelerationNode.ts
@@ -0,0 +1,90 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleAccelerationState = require("awayjs-renderergl/lib/animators/states/ParticleAccelerationState");
+
+/**
+ * A particle animation node used to apply a constant acceleration vector to the motion of a particle.
+ */
+class ParticleAccelerationNode extends ParticleNodeBase
+{
+ /** @private */
+ public _acceleration:Vector3D;
+
+ /**
+ * Reference for acceleration node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
object representing the direction of acceleration on the particle.
+ */
+ public static ACCELERATION_VECTOR3D:string = "AccelerationVector3D";
+
+ /**
+ * Creates a new ParticleAccelerationNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] acceleration Defines the default acceleration vector of the node, used when in global mode.
+ */
+ constructor(mode:number /*uint*/, acceleration:Vector3D = null)
+ {
+ super("ParticleAcceleration", mode, 3);
+
+ this._pStateClass = ParticleAccelerationState;
+
+ this._acceleration = acceleration || new Vector3D();
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public pGetAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ var accelerationValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleAccelerationState.ACCELERATION_INDEX, accelerationValue.index);
+
+ var temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp, 1);
+
+ var code:string = "mul " + temp + "," + animationRegisterCache.vertexTime + "," + accelerationValue + "\n";
+
+ if (animationRegisterCache.needVelocity) {
+ var temp2:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ code += "mul " + temp2 + "," + temp + "," + animationRegisterCache.vertexTwoConst + "\n";
+ code += "add " + animationRegisterCache.velocityTarget + ".xyz," + temp2 + ".xyz," + animationRegisterCache.velocityTarget + ".xyz\n";
+ }
+ animationRegisterCache.removeVertexTempUsage(temp);
+
+ code += "mul " + temp + "," + temp + "," + animationRegisterCache.vertexTime + "\n";
+ code += "add " + animationRegisterCache.positionTarget + ".xyz," + temp + "," + animationRegisterCache.positionTarget + ".xyz\n";
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):ParticleAccelerationState
+ {
+ return animator.getAnimationState(this);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iGeneratePropertyOfOneParticle(param:ParticleProperties)
+ {
+ var tempAcceleration:Vector3D = param[ParticleAccelerationNode.ACCELERATION_VECTOR3D];
+ if (!tempAcceleration)
+ throw new Error("there is no " + ParticleAccelerationNode.ACCELERATION_VECTOR3D + " in param!");
+
+ this._pOneData[0] = tempAcceleration.x/2;
+ this._pOneData[1] = tempAcceleration.y/2;
+ this._pOneData[2] = tempAcceleration.z/2;
+ }
+}
+
+export = ParticleAccelerationNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleBezierCurveNode.js b/lib/animators/nodes/ParticleBezierCurveNode.js
new file mode 100755
index 000000000..5600fb9f9
--- /dev/null
+++ b/lib/animators/nodes/ParticleBezierCurveNode.js
@@ -0,0 +1,105 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+var ParticleBezierCurveState = require("awayjs-renderergl/lib/animators/states/ParticleBezierCurveState");
+/**
+ * A particle animation node used to control the position of a particle over time along a bezier curve.
+ */
+var ParticleBezierCurveNode = (function (_super) {
+ __extends(ParticleBezierCurveNode, _super);
+ /**
+ * Creates a new ParticleBezierCurveNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] controlPoint Defines the default control point of the node, used when in global mode.
+ * @param [optional] endPoint Defines the default end point of the node, used when in global mode.
+ */
+ function ParticleBezierCurveNode(mode /*uint*/, controlPoint, endPoint) {
+ if (controlPoint === void 0) { controlPoint = null; }
+ if (endPoint === void 0) { endPoint = null; }
+ _super.call(this, "ParticleBezierCurve", mode, 6);
+ this._pStateClass = ParticleBezierCurveState;
+ this._iControlPoint = controlPoint || new Vector3D();
+ this._iEndPoint = endPoint || new Vector3D();
+ }
+ /**
+ * @inheritDoc
+ */
+ ParticleBezierCurveNode.prototype.getAGALVertexCode = function (shaderObject, animationRegisterCache) {
+ var controlValue = (this._pMode == ParticlePropertiesMode.GLOBAL) ? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleBezierCurveState.BEZIER_CONTROL_INDEX, controlValue.index);
+ var endValue = (this._pMode == ParticlePropertiesMode.GLOBAL) ? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleBezierCurveState.BEZIER_END_INDEX, endValue.index);
+ var temp = animationRegisterCache.getFreeVertexVectorTemp();
+ var rev_time = new ShaderRegisterElement(temp.regName, temp.index, 0);
+ var time_2 = new ShaderRegisterElement(temp.regName, temp.index, 1);
+ var time_temp = new ShaderRegisterElement(temp.regName, temp.index, 2);
+ animationRegisterCache.addVertexTempUsages(temp, 1);
+ var temp2 = animationRegisterCache.getFreeVertexVectorTemp();
+ var distance = new ShaderRegisterElement(temp2.regName, temp2.index);
+ animationRegisterCache.removeVertexTempUsage(temp);
+ var code = "";
+ code += "sub " + rev_time + "," + animationRegisterCache.vertexOneConst + "," + animationRegisterCache.vertexLife + "\n";
+ code += "mul " + time_2 + "," + animationRegisterCache.vertexLife + "," + animationRegisterCache.vertexLife + "\n";
+ code += "mul " + time_temp + "," + animationRegisterCache.vertexLife + "," + rev_time + "\n";
+ code += "mul " + time_temp + "," + time_temp + "," + animationRegisterCache.vertexTwoConst + "\n";
+ code += "mul " + distance + ".xyz," + time_temp + "," + controlValue + "\n";
+ code += "add " + animationRegisterCache.positionTarget + ".xyz," + distance + ".xyz," + animationRegisterCache.positionTarget + ".xyz\n";
+ code += "mul " + distance + ".xyz," + time_2 + "," + endValue + "\n";
+ code += "add " + animationRegisterCache.positionTarget + ".xyz," + distance + ".xyz," + animationRegisterCache.positionTarget + ".xyz\n";
+ if (animationRegisterCache.needVelocity) {
+ code += "mul " + time_2 + "," + animationRegisterCache.vertexLife + "," + animationRegisterCache.vertexTwoConst + "\n";
+ code += "sub " + time_temp + "," + animationRegisterCache.vertexOneConst + "," + time_2 + "\n";
+ code += "mul " + time_temp + "," + animationRegisterCache.vertexTwoConst + "," + time_temp + "\n";
+ code += "mul " + distance + ".xyz," + controlValue + "," + time_temp + "\n";
+ code += "add " + animationRegisterCache.velocityTarget + ".xyz," + distance + ".xyz," + animationRegisterCache.velocityTarget + ".xyz\n";
+ code += "mul " + distance + ".xyz," + endValue + "," + time_2 + "\n";
+ code += "add " + animationRegisterCache.velocityTarget + ".xyz," + distance + ".xyz," + animationRegisterCache.velocityTarget + ".xyz\n";
+ }
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleBezierCurveNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleBezierCurveNode.prototype._iGeneratePropertyOfOneParticle = function (param) {
+ var bezierControl = param[ParticleBezierCurveNode.BEZIER_CONTROL_VECTOR3D];
+ if (!bezierControl)
+ throw new Error("there is no " + ParticleBezierCurveNode.BEZIER_CONTROL_VECTOR3D + " in param!");
+ var bezierEnd = param[ParticleBezierCurveNode.BEZIER_END_VECTOR3D];
+ if (!bezierEnd)
+ throw new Error("there is no " + ParticleBezierCurveNode.BEZIER_END_VECTOR3D + " in param!");
+ this._pOneData[0] = bezierControl.x;
+ this._pOneData[1] = bezierControl.y;
+ this._pOneData[2] = bezierControl.z;
+ this._pOneData[3] = bezierEnd.x;
+ this._pOneData[4] = bezierEnd.y;
+ this._pOneData[5] = bezierEnd.z;
+ };
+ /**
+ * Reference for bezier curve node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
object representing the control point position (0, 1, 2) of the curve.
+ */
+ ParticleBezierCurveNode.BEZIER_CONTROL_VECTOR3D = "BezierControlVector3D";
+ /**
+ * Reference for bezier curve node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
object representing the end point position (0, 1, 2) of the curve.
+ */
+ ParticleBezierCurveNode.BEZIER_END_VECTOR3D = "BezierEndVector3D";
+ return ParticleBezierCurveNode;
+})(ParticleNodeBase);
+module.exports = ParticleBezierCurveNode;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/nodes/particlebeziercurvenode.ts"],"names":["ParticleBezierCurveNode","ParticleBezierCurveNode.constructor","ParticleBezierCurveNode.getAGALVertexCode","ParticleBezierCurveNode.getAnimationState","ParticleBezierCurveNode._iGeneratePropertyOfOneParticle"],"mappings":"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","file":"animators/nodes/ParticleBezierCurveNode.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\n\nimport ParticleProperties\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleProperties\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleNodeBase\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleNodeBase\");\nimport ParticleBezierCurveState\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleBezierCurveState\");\n\n/**\n * A particle animation node used to control the position of a particle over time along a bezier curve.\n */\nclass ParticleBezierCurveNode extends ParticleNodeBase\n{\n\t/** @private */\n\tpublic _iControlPoint:Vector3D;\n\t/** @private */\n\tpublic _iEndPoint:Vector3D;\n\n\t/**\n\t * Reference for bezier curve node properties on a single particle (when in local property mode).\n\t * Expects a <code>Vector3D</code> object representing the control point position (0, 1, 2) of the curve.\n\t */\n\tpublic static BEZIER_CONTROL_VECTOR3D:string = \"BezierControlVector3D\";\n\n\t/**\n\t * Reference for bezier curve node properties on a single particle (when in local property mode).\n\t * Expects a <code>Vector3D</code> object representing the end point position (0, 1, 2) of the curve.\n\t */\n\tpublic static BEZIER_END_VECTOR3D:string = \"BezierEndVector3D\";\n\n\t/**\n\t * Creates a new <code>ParticleBezierCurveNode</code>\n\t *\n\t * @param               mode            Defines whether the mode of operation acts on local properties of a particle or global properties of the node.\n\t * @param    [optional] controlPoint    Defines the default control point of the node, used when in global mode.\n\t * @param    [optional] endPoint        Defines the default end point of the node, used when in global mode.\n\t */\n\tconstructor(mode:number /*uint*/, controlPoint:Vector3D = null, endPoint:Vector3D = null)\n\t{\n\t\tsuper(\"ParticleBezierCurve\", mode, 6);\n\n\t\tthis._pStateClass = ParticleBezierCurveState;\n\n\t\tthis._iControlPoint = controlPoint || new Vector3D();\n\t\tthis._iEndPoint = endPoint || new Vector3D();\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string\n\t{\n\t\tvar controlValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();\n\t\tanimationRegisterCache.setRegisterIndex(this, ParticleBezierCurveState.BEZIER_CONTROL_INDEX, controlValue.index);\n\n\t\tvar endValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();\n\t\tanimationRegisterCache.setRegisterIndex(this, ParticleBezierCurveState.BEZIER_END_INDEX, endValue.index);\n\n\t\tvar temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\tvar rev_time:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 0);\n\t\tvar time_2:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 1);\n\t\tvar time_temp:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 2);\n\t\tanimationRegisterCache.addVertexTempUsages(temp, 1);\n\t\tvar temp2:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\tvar distance:ShaderRegisterElement = new ShaderRegisterElement(temp2.regName, temp2.index);\n\t\tanimationRegisterCache.removeVertexTempUsage(temp);\n\n\t\tvar code:string = \"\";\n\t\tcode += \"sub \" + rev_time + \",\" + animationRegisterCache.vertexOneConst + \",\" + animationRegisterCache.vertexLife + \"\\n\";\n\t\tcode += \"mul \" + time_2 + \",\" + animationRegisterCache.vertexLife + \",\" + animationRegisterCache.vertexLife + \"\\n\";\n\n\t\tcode += \"mul \" + time_temp + \",\" + animationRegisterCache.vertexLife + \",\" + rev_time + \"\\n\";\n\t\tcode += \"mul \" + time_temp + \",\" + time_temp + \",\" + animationRegisterCache.vertexTwoConst + \"\\n\";\n\t\tcode += \"mul \" + distance + \".xyz,\" + time_temp + \",\" + controlValue + \"\\n\";\n\t\tcode += \"add \" + animationRegisterCache.positionTarget + \".xyz,\" + distance + \".xyz,\" + animationRegisterCache.positionTarget + \".xyz\\n\";\n\t\tcode += \"mul \" + distance + \".xyz,\" + time_2 + \",\" + endValue + \"\\n\";\n\t\tcode += \"add \" + animationRegisterCache.positionTarget + \".xyz,\" + distance + \".xyz,\" + animationRegisterCache.positionTarget + \".xyz\\n\";\n\n\t\tif (animationRegisterCache.needVelocity) {\n\t\t\tcode += \"mul \" + time_2 + \",\" + animationRegisterCache.vertexLife + \",\" + animationRegisterCache.vertexTwoConst + \"\\n\";\n\t\t\tcode += \"sub \" + time_temp + \",\" + animationRegisterCache.vertexOneConst + \",\" + time_2 + \"\\n\";\n\t\t\tcode += \"mul \" + time_temp + \",\" + animationRegisterCache.vertexTwoConst + \",\" + time_temp + \"\\n\";\n\t\t\tcode += \"mul \" + distance + \".xyz,\" + controlValue + \",\" + time_temp + \"\\n\";\n\t\t\tcode += \"add \" + animationRegisterCache.velocityTarget + \".xyz,\" + distance + \".xyz,\" + animationRegisterCache.velocityTarget + \".xyz\\n\";\n\t\t\tcode += \"mul \" + distance + \".xyz,\" + endValue + \",\" + time_2 + \"\\n\";\n\t\t\tcode += \"add \" + animationRegisterCache.velocityTarget + \".xyz,\" + distance + \".xyz,\" + animationRegisterCache.velocityTarget + \".xyz\\n\";\n\t\t}\n\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAnimationState(animator:AnimatorBase):ParticleBezierCurveState\n\t{\n\t\treturn <ParticleBezierCurveState> animator.getAnimationState(this);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _iGeneratePropertyOfOneParticle(param:ParticleProperties)\n\t{\n\t\tvar bezierControl:Vector3D = param[ParticleBezierCurveNode.BEZIER_CONTROL_VECTOR3D];\n\t\tif (!bezierControl)\n\t\t\tthrow new Error(\"there is no \" + ParticleBezierCurveNode.BEZIER_CONTROL_VECTOR3D + \" in param!\");\n\n\t\tvar bezierEnd:Vector3D = param[ParticleBezierCurveNode.BEZIER_END_VECTOR3D];\n\t\tif (!bezierEnd)\n\t\t\tthrow new Error(\"there is no \" + ParticleBezierCurveNode.BEZIER_END_VECTOR3D + \" in param!\");\n\n\t\tthis._pOneData[0] = bezierControl.x;\n\t\tthis._pOneData[1] = bezierControl.y;\n\t\tthis._pOneData[2] = bezierControl.z;\n\t\tthis._pOneData[3] = bezierEnd.x;\n\t\tthis._pOneData[4] = bezierEnd.y;\n\t\tthis._pOneData[5] = bezierEnd.z;\n\t}\n}\n\nexport = ParticleBezierCurveNode;"]}
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleBezierCurveNode.ts b/lib/animators/nodes/ParticleBezierCurveNode.ts
new file mode 100644
index 000000000..fffadb4ba
--- /dev/null
+++ b/lib/animators/nodes/ParticleBezierCurveNode.ts
@@ -0,0 +1,126 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleBezierCurveState = require("awayjs-renderergl/lib/animators/states/ParticleBezierCurveState");
+
+/**
+ * A particle animation node used to control the position of a particle over time along a bezier curve.
+ */
+class ParticleBezierCurveNode extends ParticleNodeBase
+{
+ /** @private */
+ public _iControlPoint:Vector3D;
+ /** @private */
+ public _iEndPoint:Vector3D;
+
+ /**
+ * Reference for bezier curve node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
object representing the control point position (0, 1, 2) of the curve.
+ */
+ public static BEZIER_CONTROL_VECTOR3D:string = "BezierControlVector3D";
+
+ /**
+ * Reference for bezier curve node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
object representing the end point position (0, 1, 2) of the curve.
+ */
+ public static BEZIER_END_VECTOR3D:string = "BezierEndVector3D";
+
+ /**
+ * Creates a new ParticleBezierCurveNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] controlPoint Defines the default control point of the node, used when in global mode.
+ * @param [optional] endPoint Defines the default end point of the node, used when in global mode.
+ */
+ constructor(mode:number /*uint*/, controlPoint:Vector3D = null, endPoint:Vector3D = null)
+ {
+ super("ParticleBezierCurve", mode, 6);
+
+ this._pStateClass = ParticleBezierCurveState;
+
+ this._iControlPoint = controlPoint || new Vector3D();
+ this._iEndPoint = endPoint || new Vector3D();
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ var controlValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleBezierCurveState.BEZIER_CONTROL_INDEX, controlValue.index);
+
+ var endValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleBezierCurveState.BEZIER_END_INDEX, endValue.index);
+
+ var temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ var rev_time:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 0);
+ var time_2:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 1);
+ var time_temp:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 2);
+ animationRegisterCache.addVertexTempUsages(temp, 1);
+ var temp2:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ var distance:ShaderRegisterElement = new ShaderRegisterElement(temp2.regName, temp2.index);
+ animationRegisterCache.removeVertexTempUsage(temp);
+
+ var code:string = "";
+ code += "sub " + rev_time + "," + animationRegisterCache.vertexOneConst + "," + animationRegisterCache.vertexLife + "\n";
+ code += "mul " + time_2 + "," + animationRegisterCache.vertexLife + "," + animationRegisterCache.vertexLife + "\n";
+
+ code += "mul " + time_temp + "," + animationRegisterCache.vertexLife + "," + rev_time + "\n";
+ code += "mul " + time_temp + "," + time_temp + "," + animationRegisterCache.vertexTwoConst + "\n";
+ code += "mul " + distance + ".xyz," + time_temp + "," + controlValue + "\n";
+ code += "add " + animationRegisterCache.positionTarget + ".xyz," + distance + ".xyz," + animationRegisterCache.positionTarget + ".xyz\n";
+ code += "mul " + distance + ".xyz," + time_2 + "," + endValue + "\n";
+ code += "add " + animationRegisterCache.positionTarget + ".xyz," + distance + ".xyz," + animationRegisterCache.positionTarget + ".xyz\n";
+
+ if (animationRegisterCache.needVelocity) {
+ code += "mul " + time_2 + "," + animationRegisterCache.vertexLife + "," + animationRegisterCache.vertexTwoConst + "\n";
+ code += "sub " + time_temp + "," + animationRegisterCache.vertexOneConst + "," + time_2 + "\n";
+ code += "mul " + time_temp + "," + animationRegisterCache.vertexTwoConst + "," + time_temp + "\n";
+ code += "mul " + distance + ".xyz," + controlValue + "," + time_temp + "\n";
+ code += "add " + animationRegisterCache.velocityTarget + ".xyz," + distance + ".xyz," + animationRegisterCache.velocityTarget + ".xyz\n";
+ code += "mul " + distance + ".xyz," + endValue + "," + time_2 + "\n";
+ code += "add " + animationRegisterCache.velocityTarget + ".xyz," + distance + ".xyz," + animationRegisterCache.velocityTarget + ".xyz\n";
+ }
+
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):ParticleBezierCurveState
+ {
+ return animator.getAnimationState(this);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iGeneratePropertyOfOneParticle(param:ParticleProperties)
+ {
+ var bezierControl:Vector3D = param[ParticleBezierCurveNode.BEZIER_CONTROL_VECTOR3D];
+ if (!bezierControl)
+ throw new Error("there is no " + ParticleBezierCurveNode.BEZIER_CONTROL_VECTOR3D + " in param!");
+
+ var bezierEnd:Vector3D = param[ParticleBezierCurveNode.BEZIER_END_VECTOR3D];
+ if (!bezierEnd)
+ throw new Error("there is no " + ParticleBezierCurveNode.BEZIER_END_VECTOR3D + " in param!");
+
+ this._pOneData[0] = bezierControl.x;
+ this._pOneData[1] = bezierControl.y;
+ this._pOneData[2] = bezierControl.z;
+ this._pOneData[3] = bezierEnd.x;
+ this._pOneData[4] = bezierEnd.y;
+ this._pOneData[5] = bezierEnd.z;
+ }
+}
+
+export = ParticleBezierCurveNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleBillboardNode.js b/lib/animators/nodes/ParticleBillboardNode.js
new file mode 100755
index 000000000..4042e0be2
--- /dev/null
+++ b/lib/animators/nodes/ParticleBillboardNode.js
@@ -0,0 +1,58 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+var ParticleBillboardState = require("awayjs-renderergl/lib/animators/states/ParticleBillboardState");
+/**
+ * A particle animation node that controls the rotation of a particle to always face the camera.
+ */
+var ParticleBillboardNode = (function (_super) {
+ __extends(ParticleBillboardNode, _super);
+ /**
+ * Creates a new ParticleBillboardNode
+ */
+ function ParticleBillboardNode(billboardAxis) {
+ if (billboardAxis === void 0) { billboardAxis = null; }
+ _super.call(this, "ParticleBillboard", ParticlePropertiesMode.GLOBAL, 0, 4);
+ this._pStateClass = ParticleBillboardState;
+ this._iBillboardAxis = billboardAxis;
+ }
+ /**
+ * @inheritDoc
+ */
+ ParticleBillboardNode.prototype.getAGALVertexCode = function (shaderObject, animationRegisterCache) {
+ var rotationMatrixRegister = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleBillboardState.MATRIX_INDEX, rotationMatrixRegister.index);
+ animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.getFreeVertexConstant();
+ var temp = animationRegisterCache.getFreeVertexVectorTemp();
+ var code = "m33 " + temp + ".xyz," + animationRegisterCache.scaleAndRotateTarget + "," + rotationMatrixRegister + "\n" + "mov " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + temp + "\n";
+ var shaderRegisterElement;
+ for (var i = 0; i < animationRegisterCache.rotationRegisters.length; i++) {
+ shaderRegisterElement = animationRegisterCache.rotationRegisters[i];
+ code += "m33 " + temp + ".xyz," + shaderRegisterElement + "," + rotationMatrixRegister + "\n" + "mov " + shaderRegisterElement + ".xyz," + shaderRegisterElement + "\n";
+ }
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleBillboardNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleBillboardNode.prototype._iProcessAnimationSetting = function (particleAnimationSet) {
+ particleAnimationSet.hasBillboard = true;
+ };
+ return ParticleBillboardNode;
+})(ParticleNodeBase);
+module.exports = ParticleBillboardNode;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9ub2Rlcy9wYXJ0aWNsZWJpbGxib2FyZG5vZGUudHMiXSwibmFtZXMiOlsiUGFydGljbGVCaWxsYm9hcmROb2RlIiwiUGFydGljbGVCaWxsYm9hcmROb2RlLmNvbnN0cnVjdG9yIiwiUGFydGljbGVCaWxsYm9hcmROb2RlLmdldEFHQUxWZXJ0ZXhDb2RlIiwiUGFydGljbGVCaWxsYm9hcmROb2RlLmdldEFuaW1hdGlvblN0YXRlIiwiUGFydGljbGVCaWxsYm9hcmROb2RlLl9pUHJvY2Vzc0FuaW1hdGlvblNldHRpbmciXSwibWFwcGluZ3MiOiI7Ozs7OztBQVNBLElBQU8sc0JBQXNCLFdBQWEsNkRBQTZELENBQUMsQ0FBQztBQUN6RyxJQUFPLGdCQUFnQixXQUFlLHdEQUF3RCxDQUFDLENBQUM7QUFDaEcsSUFBTyxzQkFBc0IsV0FBYSwrREFBK0QsQ0FBQyxDQUFDO0FBRTNHLEFBR0E7O0dBREc7SUFDRyxxQkFBcUI7SUFBU0EsVUFBOUJBLHFCQUFxQkEsVUFBeUJBO0lBS25EQTs7T0FFR0E7SUFDSEEsU0FSS0EscUJBQXFCQSxDQVFkQSxhQUE2QkE7UUFBN0JDLDZCQUE2QkEsR0FBN0JBLG9CQUE2QkE7UUFFeENBLGtCQUFNQSxtQkFBbUJBLEVBQUVBLHNCQUFzQkEsQ0FBQ0EsTUFBTUEsRUFBRUEsQ0FBQ0EsRUFBRUEsQ0FBQ0EsQ0FBQ0EsQ0FBQ0E7UUFFaEVBLElBQUlBLENBQUNBLFlBQVlBLEdBQUdBLHNCQUFzQkEsQ0FBQ0E7UUFFM0NBLElBQUlBLENBQUNBLGVBQWVBLEdBQUdBLGFBQWFBLENBQUNBO0lBQ3RDQSxDQUFDQTtJQUVERDs7T0FFR0E7SUFDSUEsaURBQWlCQSxHQUF4QkEsVUFBeUJBLFlBQTZCQSxFQUFFQSxzQkFBNkNBO1FBRXBHRSxJQUFJQSxzQkFBc0JBLEdBQXlCQSxzQkFBc0JBLENBQUNBLHFCQUFxQkEsRUFBRUEsQ0FBQ0E7UUFDbEdBLHNCQUFzQkEsQ0FBQ0EsZ0JBQWdCQSxDQUFDQSxJQUFJQSxFQUFFQSxzQkFBc0JBLENBQUNBLFlBQVlBLEVBQUVBLHNCQUFzQkEsQ0FBQ0EsS0FBS0EsQ0FBQ0EsQ0FBQ0E7UUFDakhBLHNCQUFzQkEsQ0FBQ0EscUJBQXFCQSxFQUFFQSxDQUFDQTtRQUMvQ0Esc0JBQXNCQSxDQUFDQSxxQkFBcUJBLEVBQUVBLENBQUNBO1FBQy9DQSxzQkFBc0JBLENBQUNBLHFCQUFxQkEsRUFBRUEsQ0FBQ0E7UUFFL0NBLElBQUlBLElBQUlBLEdBQXlCQSxzQkFBc0JBLENBQUNBLHVCQUF1QkEsRUFBRUEsQ0FBQ0E7UUFFbEZBLElBQUlBLElBQUlBLEdBQVVBLE1BQU1BLEdBQUdBLElBQUlBLEdBQUdBLE9BQU9BLEdBQUdBLHNCQUFzQkEsQ0FBQ0Esb0JBQW9CQSxHQUFHQSxHQUFHQSxHQUFHQSxzQkFBc0JBLEdBQUdBLElBQUlBLEdBQ3ZIQSxNQUFNQSxHQUFHQSxzQkFBc0JBLENBQUNBLG9CQUFvQkEsR0FBR0EsT0FBT0EsR0FBR0EsSUFBSUEsR0FBR0EsSUFBSUEsQ0FBQ0E7UUFFbkZBLElBQUlBLHFCQUEyQ0EsQ0FBQ0E7UUFDaERBLEdBQUdBLENBQUNBLENBQUNBLEdBQUdBLENBQUNBLENBQUNBLEdBQW1CQSxDQUFDQSxFQUFFQSxDQUFDQSxHQUFHQSxzQkFBc0JBLENBQUNBLGlCQUFpQkEsQ0FBQ0EsTUFBTUEsRUFBRUEsQ0FBQ0EsRUFBRUEsRUFBRUEsQ0FBQ0E7WUFDMUZBLHFCQUFxQkEsR0FBR0Esc0JBQXNCQSxDQUFDQSxpQkFBaUJBLENBQUNBLENBQUNBLENBQUNBLENBQUNBO1lBQ3BFQSxJQUFJQSxJQUFJQSxNQUFNQSxHQUFHQSxJQUFJQSxHQUFHQSxPQUFPQSxHQUFHQSxxQkFBcUJBLEdBQUdBLEdBQUdBLEdBQUdBLHNCQUFzQkEsR0FBR0EsSUFBSUEsR0FDM0ZBLE1BQU1BLEdBQUdBLHFCQUFxQkEsR0FBR0EsT0FBT0EsR0FBR0EscUJBQXFCQSxHQUFHQSxJQUFJQSxDQUFDQTtRQUMzRUEsQ0FBQ0E7UUFFREEsTUFBTUEsQ0FBQ0EsSUFBSUEsQ0FBQ0E7SUFDYkEsQ0FBQ0E7SUFFREY7O09BRUdBO0lBQ0lBLGlEQUFpQkEsR0FBeEJBLFVBQXlCQSxRQUFxQkE7UUFFN0NHLE1BQU1BLENBQTBCQSxRQUFRQSxDQUFDQSxpQkFBaUJBLENBQUNBLElBQUlBLENBQUNBLENBQUNBO0lBQ2xFQSxDQUFDQTtJQUVESDs7T0FFR0E7SUFDSUEseURBQXlCQSxHQUFoQ0EsVUFBaUNBLG9CQUF5Q0E7UUFFekVJLG9CQUFvQkEsQ0FBQ0EsWUFBWUEsR0FBR0EsSUFBSUEsQ0FBQ0E7SUFDMUNBLENBQUNBO0lBQ0ZKLDRCQUFDQTtBQUFEQSxDQTFEQSxBQTBEQ0EsRUExRG1DLGdCQUFnQixFQTBEbkQ7QUFFRCxBQUErQixpQkFBdEIscUJBQXFCLENBQUMiLCJmaWxlIjoiYW5pbWF0b3JzL25vZGVzL1BhcnRpY2xlQmlsbGJvYXJkTm9kZS5qcyIsInNvdXJjZVJvb3QiOiIvVXNlcnMvcm9iYmF0ZW1hbi9XZWJzdG9ybVByb2plY3RzL2F3YXlqcy1yZW5kZXJlcmdsLyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBWZWN0b3IzRFx0XHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLWNvcmUvbGliL2NvcmUvZ2VvbS9WZWN0b3IzRFwiKTtcblxuaW1wb3J0IEFuaW1hdG9yQmFzZVx0XHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1zdGFnZWdsL2xpYi9hbmltYXRvcnMvQW5pbWF0b3JCYXNlXCIpO1xuaW1wb3J0IEFuaW1hdGlvblJlZ2lzdGVyQ2FjaGVcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvYW5pbWF0b3JzL2RhdGEvQW5pbWF0aW9uUmVnaXN0ZXJDYWNoZVwiKTtcbmltcG9ydCBTaGFkZXJPYmplY3RCYXNlXHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1zdGFnZWdsL2xpYi9tYXRlcmlhbHMvY29tcGlsYXRpb24vU2hhZGVyT2JqZWN0QmFzZVwiKTtcbmltcG9ydCBTaGFkZXJSZWdpc3RlckVsZW1lbnRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvbWF0ZXJpYWxzL2NvbXBpbGF0aW9uL1NoYWRlclJlZ2lzdGVyRWxlbWVudFwiKTtcblxuaW1wb3J0IFBhcnRpY2xlQW5pbWF0aW9uU2V0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL1BhcnRpY2xlQW5pbWF0aW9uU2V0XCIpO1xuaW1wb3J0IFBhcnRpY2xlUHJvcGVydGllc1x0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXJlbmRlcmVyZ2wvbGliL2FuaW1hdG9ycy9kYXRhL1BhcnRpY2xlUHJvcGVydGllc1wiKTtcbmltcG9ydCBQYXJ0aWNsZVByb3BlcnRpZXNNb2RlXHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXJlbmRlcmVyZ2wvbGliL2FuaW1hdG9ycy9kYXRhL1BhcnRpY2xlUHJvcGVydGllc01vZGVcIik7XG5pbXBvcnQgUGFydGljbGVOb2RlQmFzZVx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL25vZGVzL1BhcnRpY2xlTm9kZUJhc2VcIik7XG5pbXBvcnQgUGFydGljbGVCaWxsYm9hcmRTdGF0ZVx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvc3RhdGVzL1BhcnRpY2xlQmlsbGJvYXJkU3RhdGVcIik7XG5cbi8qKlxuICogQSBwYXJ0aWNsZSBhbmltYXRpb24gbm9kZSB0aGF0IGNvbnRyb2xzIHRoZSByb3RhdGlvbiBvZiBhIHBhcnRpY2xlIHRvIGFsd2F5cyBmYWNlIHRoZSBjYW1lcmEuXG4gKi9cbmNsYXNzIFBhcnRpY2xlQmlsbGJvYXJkTm9kZSBleHRlbmRzIFBhcnRpY2xlTm9kZUJhc2Vcbntcblx0LyoqIEBwcml2YXRlICovXG5cdHB1YmxpYyBfaUJpbGxib2FyZEF4aXM6VmVjdG9yM0Q7XG5cblx0LyoqXG5cdCAqIENyZWF0ZXMgYSBuZXcgPGNvZGU+UGFydGljbGVCaWxsYm9hcmROb2RlPC9jb2RlPlxuXHQgKi9cblx0Y29uc3RydWN0b3IoYmlsbGJvYXJkQXhpczpWZWN0b3IzRCA9IG51bGwpXG5cdHtcblx0XHRzdXBlcihcIlBhcnRpY2xlQmlsbGJvYXJkXCIsIFBhcnRpY2xlUHJvcGVydGllc01vZGUuR0xPQkFMLCAwLCA0KTtcblxuXHRcdHRoaXMuX3BTdGF0ZUNsYXNzID0gUGFydGljbGVCaWxsYm9hcmRTdGF0ZTtcblxuXHRcdHRoaXMuX2lCaWxsYm9hcmRBeGlzID0gYmlsbGJvYXJkQXhpcztcblx0fVxuXG5cdC8qKlxuXHQgKiBAaW5oZXJpdERvY1xuXHQgKi9cblx0cHVibGljIGdldEFHQUxWZXJ0ZXhDb2RlKHNoYWRlck9iamVjdDpTaGFkZXJPYmplY3RCYXNlLCBhbmltYXRpb25SZWdpc3RlckNhY2hlOkFuaW1hdGlvblJlZ2lzdGVyQ2FjaGUpOnN0cmluZ1xuXHR7XG5cdFx0dmFyIHJvdGF0aW9uTWF0cml4UmVnaXN0ZXI6U2hhZGVyUmVnaXN0ZXJFbGVtZW50ID0gYW5pbWF0aW9uUmVnaXN0ZXJDYWNoZS5nZXRGcmVlVmVydGV4Q29uc3RhbnQoKTtcblx0XHRhbmltYXRpb25SZWdpc3RlckNhY2hlLnNldFJlZ2lzdGVySW5kZXgodGhpcywgUGFydGljbGVCaWxsYm9hcmRTdGF0ZS5NQVRSSVhfSU5ERVgsIHJvdGF0aW9uTWF0cml4UmVnaXN0ZXIuaW5kZXgpO1xuXHRcdGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGUuZ2V0RnJlZVZlcnRleENvbnN0YW50KCk7XG5cdFx0YW5pbWF0aW9uUmVnaXN0ZXJDYWNoZS5nZXRGcmVlVmVydGV4Q29uc3RhbnQoKTtcblx0XHRhbmltYXRpb25SZWdpc3RlckNhY2hlLmdldEZyZWVWZXJ0ZXhDb25zdGFudCgpO1xuXG5cdFx0dmFyIHRlbXA6U2hhZGVyUmVnaXN0ZXJFbGVtZW50ID0gYW5pbWF0aW9uUmVnaXN0ZXJDYWNoZS5nZXRGcmVlVmVydGV4VmVjdG9yVGVtcCgpO1xuXG5cdFx0dmFyIGNvZGU6c3RyaW5nID0gXCJtMzMgXCIgKyB0ZW1wICsgXCIueHl6LFwiICsgYW5pbWF0aW9uUmVnaXN0ZXJDYWNoZS5zY2FsZUFuZFJvdGF0ZVRhcmdldCArIFwiLFwiICsgcm90YXRpb25NYXRyaXhSZWdpc3RlciArIFwiXFxuXCIgK1xuXHRcdFx0XHRcdFx0ICBcIm1vdiBcIiArIGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGUuc2NhbGVBbmRSb3RhdGVUYXJnZXQgKyBcIi54eXosXCIgKyB0ZW1wICsgXCJcXG5cIjtcblxuXHRcdHZhciBzaGFkZXJSZWdpc3RlckVsZW1lbnQ6U2hhZGVyUmVnaXN0ZXJFbGVtZW50O1xuXHRcdGZvciAodmFyIGk6bnVtYmVyIC8qdWludCovID0gMDsgaSA8IGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGUucm90YXRpb25SZWdpc3RlcnMubGVuZ3RoOyBpKyspIHtcblx0XHRcdHNoYWRlclJlZ2lzdGVyRWxlbWVudCA9IGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGUucm90YXRpb25SZWdpc3RlcnNbaV07XG5cdFx0XHRjb2RlICs9IFwibTMzIFwiICsgdGVtcCArIFwiLnh5eixcIiArIHNoYWRlclJlZ2lzdGVyRWxlbWVudCArIFwiLFwiICsgcm90YXRpb25NYXRyaXhSZWdpc3RlciArIFwiXFxuXCIgK1xuXHRcdFx0XHRcdFwibW92IFwiICsgc2hhZGVyUmVnaXN0ZXJFbGVtZW50ICsgXCIueHl6LFwiICsgc2hhZGVyUmVnaXN0ZXJFbGVtZW50ICsgXCJcXG5cIjtcblx0XHR9XG5cblx0XHRyZXR1cm4gY29kZTtcblx0fVxuXG5cdC8qKlxuXHQgKiBAaW5oZXJpdERvY1xuXHQgKi9cblx0cHVibGljIGdldEFuaW1hdGlvblN0YXRlKGFuaW1hdG9yOkFuaW1hdG9yQmFzZSk6UGFydGljbGVCaWxsYm9hcmRTdGF0ZVxuXHR7XG5cdFx0cmV0dXJuIDxQYXJ0aWNsZUJpbGxib2FyZFN0YXRlPiBhbmltYXRvci5nZXRBbmltYXRpb25TdGF0ZSh0aGlzKTtcblx0fVxuXG5cdC8qKlxuXHQgKiBAaW5oZXJpdERvY1xuXHQgKi9cblx0cHVibGljIF9pUHJvY2Vzc0FuaW1hdGlvblNldHRpbmcocGFydGljbGVBbmltYXRpb25TZXQ6UGFydGljbGVBbmltYXRpb25TZXQpXG5cdHtcblx0XHRwYXJ0aWNsZUFuaW1hdGlvblNldC5oYXNCaWxsYm9hcmQgPSB0cnVlO1xuXHR9XG59XG5cbmV4cG9ydCA9IFBhcnRpY2xlQmlsbGJvYXJkTm9kZTsiXX0=
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleBillboardNode.ts b/lib/animators/nodes/ParticleBillboardNode.ts
new file mode 100644
index 000000000..b8db77ea3
--- /dev/null
+++ b/lib/animators/nodes/ParticleBillboardNode.ts
@@ -0,0 +1,77 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+
+import ParticleAnimationSet = require("awayjs-renderergl/lib/animators/ParticleAnimationSet");
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleBillboardState = require("awayjs-renderergl/lib/animators/states/ParticleBillboardState");
+
+/**
+ * A particle animation node that controls the rotation of a particle to always face the camera.
+ */
+class ParticleBillboardNode extends ParticleNodeBase
+{
+ /** @private */
+ public _iBillboardAxis:Vector3D;
+
+ /**
+ * Creates a new ParticleBillboardNode
+ */
+ constructor(billboardAxis:Vector3D = null)
+ {
+ super("ParticleBillboard", ParticlePropertiesMode.GLOBAL, 0, 4);
+
+ this._pStateClass = ParticleBillboardState;
+
+ this._iBillboardAxis = billboardAxis;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ var rotationMatrixRegister:ShaderRegisterElement = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleBillboardState.MATRIX_INDEX, rotationMatrixRegister.index);
+ animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.getFreeVertexConstant();
+
+ var temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+
+ var code:string = "m33 " + temp + ".xyz," + animationRegisterCache.scaleAndRotateTarget + "," + rotationMatrixRegister + "\n" +
+ "mov " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + temp + "\n";
+
+ var shaderRegisterElement:ShaderRegisterElement;
+ for (var i:number /*uint*/ = 0; i < animationRegisterCache.rotationRegisters.length; i++) {
+ shaderRegisterElement = animationRegisterCache.rotationRegisters[i];
+ code += "m33 " + temp + ".xyz," + shaderRegisterElement + "," + rotationMatrixRegister + "\n" +
+ "mov " + shaderRegisterElement + ".xyz," + shaderRegisterElement + "\n";
+ }
+
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):ParticleBillboardState
+ {
+ return animator.getAnimationState(this);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iProcessAnimationSetting(particleAnimationSet:ParticleAnimationSet)
+ {
+ particleAnimationSet.hasBillboard = true;
+ }
+}
+
+export = ParticleBillboardNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleColorNode.js b/lib/animators/nodes/ParticleColorNode.js
new file mode 100755
index 000000000..e667d1d3d
--- /dev/null
+++ b/lib/animators/nodes/ParticleColorNode.js
@@ -0,0 +1,178 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var ColorTransform = require("awayjs-core/lib/core/geom/ColorTransform");
+var ParticleAnimationSet = require("awayjs-renderergl/lib/animators/ParticleAnimationSet");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+var ParticleColorState = require("awayjs-renderergl/lib/animators/states/ParticleColorState");
+/**
+ * A particle animation node used to control the color variation of a particle over time.
+ */
+var ParticleColorNode = (function (_super) {
+ __extends(ParticleColorNode, _super);
+ /**
+ * Creates a new ParticleColorNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] usesMultiplier Defines whether the node uses multiplier data in the shader for its color transformations. Defaults to true.
+ * @param [optional] usesOffset Defines whether the node uses offset data in the shader for its color transformations. Defaults to true.
+ * @param [optional] usesCycle Defines whether the node uses the cycleDuration
property in the shader to calculate the period of the animation independent of particle duration. Defaults to false.
+ * @param [optional] usesPhase Defines whether the node uses the cyclePhase
property in the shader to calculate a starting offset to the cycle rotation of the particle. Defaults to false.
+ * @param [optional] startColor Defines the default start color transform of the node, when in global mode.
+ * @param [optional] endColor Defines the default end color transform of the node, when in global mode.
+ * @param [optional] cycleDuration Defines the duration of the animation in seconds, used as a period independent of particle duration when in global mode. Defaults to 1.
+ * @param [optional] cyclePhase Defines the phase of the cycle in degrees, used as the starting offset of the cycle when in global mode. Defaults to 0.
+ */
+ function ParticleColorNode(mode /*uint*/, usesMultiplier, usesOffset, usesCycle, usesPhase, startColor, endColor, cycleDuration, cyclePhase) {
+ if (usesMultiplier === void 0) { usesMultiplier = true; }
+ if (usesOffset === void 0) { usesOffset = true; }
+ if (usesCycle === void 0) { usesCycle = false; }
+ if (usesPhase === void 0) { usesPhase = false; }
+ if (startColor === void 0) { startColor = null; }
+ if (endColor === void 0) { endColor = null; }
+ if (cycleDuration === void 0) { cycleDuration = 1; }
+ if (cyclePhase === void 0) { cyclePhase = 0; }
+ _super.call(this, "ParticleColor", mode, (usesMultiplier && usesOffset) ? 16 : 8, ParticleAnimationSet.COLOR_PRIORITY);
+ this._pStateClass = ParticleColorState;
+ this._iUsesMultiplier = usesMultiplier;
+ this._iUsesOffset = usesOffset;
+ this._iUsesCycle = usesCycle;
+ this._iUsesPhase = usesPhase;
+ this._iStartColor = startColor || new ColorTransform();
+ this._iEndColor = endColor || new ColorTransform();
+ this._iCycleDuration = cycleDuration;
+ this._iCyclePhase = cyclePhase;
+ }
+ /**
+ * @inheritDoc
+ */
+ ParticleColorNode.prototype.getAGALVertexCode = function (shaderObject, animationRegisterCache) {
+ var code = "";
+ if (animationRegisterCache.needFragmentAnimation) {
+ var temp = animationRegisterCache.getFreeVertexVectorTemp();
+ if (this._iUsesCycle) {
+ var cycleConst = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleColorState.CYCLE_INDEX, cycleConst.index);
+ animationRegisterCache.addVertexTempUsages(temp, 1);
+ var sin = animationRegisterCache.getFreeVertexSingleTemp();
+ animationRegisterCache.removeVertexTempUsage(temp);
+ code += "mul " + sin + "," + animationRegisterCache.vertexTime + "," + cycleConst + ".x\n";
+ if (this._iUsesPhase)
+ code += "add " + sin + "," + sin + "," + cycleConst + ".y\n";
+ code += "sin " + sin + "," + sin + "\n";
+ }
+ if (this._iUsesMultiplier) {
+ var startMultiplierValue = (this._pMode == ParticlePropertiesMode.GLOBAL) ? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ var deltaMultiplierValue = (this._pMode == ParticlePropertiesMode.GLOBAL) ? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleColorState.START_MULTIPLIER_INDEX, startMultiplierValue.index);
+ animationRegisterCache.setRegisterIndex(this, ParticleColorState.DELTA_MULTIPLIER_INDEX, deltaMultiplierValue.index);
+ code += "mul " + temp + "," + deltaMultiplierValue + "," + (this._iUsesCycle ? sin : animationRegisterCache.vertexLife) + "\n";
+ code += "add " + temp + "," + temp + "," + startMultiplierValue + "\n";
+ code += "mul " + animationRegisterCache.colorMulTarget + "," + temp + "," + animationRegisterCache.colorMulTarget + "\n";
+ }
+ if (this._iUsesOffset) {
+ var startOffsetValue = (this._pMode == ParticlePropertiesMode.LOCAL_STATIC) ? animationRegisterCache.getFreeVertexAttribute() : animationRegisterCache.getFreeVertexConstant();
+ var deltaOffsetValue = (this._pMode == ParticlePropertiesMode.LOCAL_STATIC) ? animationRegisterCache.getFreeVertexAttribute() : animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleColorState.START_OFFSET_INDEX, startOffsetValue.index);
+ animationRegisterCache.setRegisterIndex(this, ParticleColorState.DELTA_OFFSET_INDEX, deltaOffsetValue.index);
+ code += "mul " + temp + "," + deltaOffsetValue + "," + (this._iUsesCycle ? sin : animationRegisterCache.vertexLife) + "\n";
+ code += "add " + temp + "," + temp + "," + startOffsetValue + "\n";
+ code += "add " + animationRegisterCache.colorAddTarget + "," + temp + "," + animationRegisterCache.colorAddTarget + "\n";
+ }
+ }
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleColorNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleColorNode.prototype._iProcessAnimationSetting = function (particleAnimationSet) {
+ if (this._iUsesMultiplier)
+ particleAnimationSet.hasColorMulNode = true;
+ if (this._iUsesOffset)
+ particleAnimationSet.hasColorAddNode = true;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleColorNode.prototype._iGeneratePropertyOfOneParticle = function (param) {
+ var startColor = param[ParticleColorNode.COLOR_START_COLORTRANSFORM];
+ if (!startColor)
+ throw (new Error("there is no " + ParticleColorNode.COLOR_START_COLORTRANSFORM + " in param!"));
+ var endColor = param[ParticleColorNode.COLOR_END_COLORTRANSFORM];
+ if (!endColor)
+ throw (new Error("there is no " + ParticleColorNode.COLOR_END_COLORTRANSFORM + " in param!"));
+ var i = 0;
+ if (!this._iUsesCycle) {
+ //multiplier
+ if (this._iUsesMultiplier) {
+ this._pOneData[i++] = startColor.redMultiplier;
+ this._pOneData[i++] = startColor.greenMultiplier;
+ this._pOneData[i++] = startColor.blueMultiplier;
+ this._pOneData[i++] = startColor.alphaMultiplier;
+ this._pOneData[i++] = endColor.redMultiplier - startColor.redMultiplier;
+ this._pOneData[i++] = endColor.greenMultiplier - startColor.greenMultiplier;
+ this._pOneData[i++] = endColor.blueMultiplier - startColor.blueMultiplier;
+ this._pOneData[i++] = endColor.alphaMultiplier - startColor.alphaMultiplier;
+ }
+ //offset
+ if (this._iUsesOffset) {
+ this._pOneData[i++] = startColor.redOffset / 255;
+ this._pOneData[i++] = startColor.greenOffset / 255;
+ this._pOneData[i++] = startColor.blueOffset / 255;
+ this._pOneData[i++] = startColor.alphaOffset / 255;
+ this._pOneData[i++] = (endColor.redOffset - startColor.redOffset) / 255;
+ this._pOneData[i++] = (endColor.greenOffset - startColor.greenOffset) / 255;
+ this._pOneData[i++] = (endColor.blueOffset - startColor.blueOffset) / 255;
+ this._pOneData[i++] = (endColor.alphaOffset - startColor.alphaOffset) / 255;
+ }
+ }
+ else {
+ //multiplier
+ if (this._iUsesMultiplier) {
+ this._pOneData[i++] = (startColor.redMultiplier + endColor.redMultiplier) / 2;
+ this._pOneData[i++] = (startColor.greenMultiplier + endColor.greenMultiplier) / 2;
+ this._pOneData[i++] = (startColor.blueMultiplier + endColor.blueMultiplier) / 2;
+ this._pOneData[i++] = (startColor.alphaMultiplier + endColor.alphaMultiplier) / 2;
+ this._pOneData[i++] = (startColor.redMultiplier - endColor.redMultiplier) / 2;
+ this._pOneData[i++] = (startColor.greenMultiplier - endColor.greenMultiplier) / 2;
+ this._pOneData[i++] = (startColor.blueMultiplier - endColor.blueMultiplier) / 2;
+ this._pOneData[i++] = (startColor.alphaMultiplier - endColor.alphaMultiplier) / 2;
+ }
+ //offset
+ if (this._iUsesOffset) {
+ this._pOneData[i++] = (startColor.redOffset + endColor.redOffset) / (255 * 2);
+ this._pOneData[i++] = (startColor.greenOffset + endColor.greenOffset) / (255 * 2);
+ this._pOneData[i++] = (startColor.blueOffset + endColor.blueOffset) / (255 * 2);
+ this._pOneData[i++] = (startColor.alphaOffset + endColor.alphaOffset) / (255 * 2);
+ this._pOneData[i++] = (startColor.redOffset - endColor.redOffset) / (255 * 2);
+ this._pOneData[i++] = (startColor.greenOffset - endColor.greenOffset) / (255 * 2);
+ this._pOneData[i++] = (startColor.blueOffset - endColor.blueOffset) / (255 * 2);
+ this._pOneData[i++] = (startColor.alphaOffset - endColor.alphaOffset) / (255 * 2);
+ }
+ }
+ };
+ /**
+ * Reference for color node properties on a single particle (when in local property mode).
+ * Expects a ColorTransform
object representing the start color transform applied to the particle.
+ */
+ ParticleColorNode.COLOR_START_COLORTRANSFORM = "ColorStartColorTransform";
+ /**
+ * Reference for color node properties on a single particle (when in local property mode).
+ * Expects a ColorTransform
object representing the end color transform applied to the particle.
+ */
+ ParticleColorNode.COLOR_END_COLORTRANSFORM = "ColorEndColorTransform";
+ return ParticleColorNode;
+})(ParticleNodeBase);
+module.exports = ParticleColorNode;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/nodes/particlecolornode.ts"],"names":["ParticleColorNode","ParticleColorNode.constructor","ParticleColorNode.getAGALVertexCode","ParticleColorNode.getAnimationState","ParticleColorNode._iProcessAnimationSetting","ParticleColorNode._iGeneratePropertyOfOneParticle"],"mappings":"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AACA;gBAC1EA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,QAAQA,CAACA,eAAeA,GAAGA,UAAUA,CAACA,eAAeA,CAACA;YAC7EA,CAACA;YAEDA,AACAA,QADQA;YACRA,EAAEA,CAACA,CAACA,IAAIA,CAACA,YAAYA,CAACA,CAACA,CAACA;gBACvBA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,UAAUA,CAACA,SAASA,GAACA,GAAGA,CAACA;gBAC/CA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,UAAUA,CAACA,WAAWA,GAACA,GAAGA,CAACA;gBACjDA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,UAAUA,CAACA,UAAUA,GAACA,GAAGA,CAACA;gBAChDA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,UAAUA,CAACA,WAAWA,GAACA,GAAGA,CAACA;gBACjDA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,QAAQA,CAACA,SAASA,GAAGA,UAAUA,CAACA,SAASA,CAACA,GAACA,GAAGA,CAACA;gBACtEA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,QAAQA,CAACA,WAAWA,GAAGA,UAAUA,CAACA,WAAWA,CAACA,GAACA,GAAGA,CAACA;gBAC1EA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,QAAQA,CAACA,UAAUA,GAAGA,UAAUA,CAACA,UAAUA,CAACA,GAACA,GAAGA,CAACA;gBACxEA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,QAAQA,CAACA,WAAWA,GAAGA,UAAUA,CAACA,WAAWA,CAACA,GAACA,GAAGA,CAACA;YAC3EA,CAACA;QACFA,CAACA;QAACA,IAAIA,CAACA,CAACA;YACPA,AACAA,YADYA;YACZA,EAAEA,CAACA,CAACA,IAAIA,CAACA,gBAAgBA,CAACA,CAACA,CAACA;gBAC3BA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,UAAUA,CAACA,aAAaA,GAAGA,QAAQA,CAACA,aAAaA,CAACA,GAACA,CAACA,CAACA;gBAC5EA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,UAAUA,CAACA,eAAeA,GAAGA,QAAQA,CAACA,eAAeA,CAACA,GAACA,CAACA,CAACA;gBAChFA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,UAAUA,CAACA,cAAcA,GAAGA,QAAQA,CAACA,cAAcA,CAACA,GAACA,CAACA,CAACA;gBAC9EA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,UAAUA,CAACA,eAAeA,GAAGA,QAAQA,CAACA,eAAeA,CAACA,GAACA,CAACA,CAACA;gBAChFA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,UAAUA,CAACA,aAAaA,GAAGA,QAAQA,CAACA,aAAaA,CAACA,GAACA,CAACA,CAACA;gBAC5EA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,UAAUA,CAACA,eAAeA,GAAGA,QAAQA,CAACA,eAAeA,CAACA,GAACA,CAACA,CAACA;gBAChFA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,UAAUA,CAACA,cAAcA,GAAGA,QAAQA,CAACA,cAAcA,CAACA,GAACA,CAACA,CAACA;gBAC9EA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,UAAUA,CAACA,eAAeA,GAAGA,QAAQA,CAACA,eAAeA,CAACA,GAACA,CAACA,CAACA;YACjFA,CAACA;YAEDA,AACAA,QADQA;YACRA,EAAEA,CAACA,CAACA,IAAIA,CAACA,YAAYA,CAACA,CAACA,CAACA;gBACvBA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,UAAUA,CAACA,SAASA,GAAGA,QAAQA,CAACA,SAASA,CAACA,GAACA,CAACA,GAAGA,GAACA,CAACA,CAACA,CAACA;gBAC1EA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,UAAUA,CAACA,WAAWA,GAAGA,QAAQA,CAACA,WAAWA,CAACA,GAACA,CAACA,GAAGA,GAACA,CAACA,CAACA,CAACA;gBAC9EA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,UAAUA,CAACA,UAAUA,GAAGA,QAAQA,CAACA,UAAUA,CAACA,GAACA,CAACA,GAAGA,GAACA,CAACA,CAACA,CAACA;gBAC5EA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,UAAUA,CAACA,WAAWA,GAAGA,QAAQA,CAACA,WAAWA,CAACA,GAACA,CAACA,GAAGA,GAACA,CAACA,CAACA,CAACA;gBAC9EA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,UAAUA,CAACA,SAASA,GAAGA,QAAQA,CAACA,SAASA,CAACA,GAACA,CAACA,GAAGA,GAACA,CAACA,CAACA,CAACA;gBAC1EA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,UAAUA,CAACA,WAAWA,GAAGA,QAAQA,CAACA,WAAWA,CAACA,GAACA,CAACA,GAAGA,GAACA,CAACA,CAACA,CAACA;gBAC9EA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,UAAUA,CAACA,UAAUA,GAAGA,QAAQA,CAACA,UAAUA,CAACA,GAACA,CAACA,GAAGA,GAACA,CAACA,CAACA,CAACA;gBAC5EA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,CAACA,UAAUA,CAACA,WAAWA,GAAGA,QAAQA,CAACA,WAAWA,CAACA,GAACA,CAACA,GAAGA,GAACA,CAACA,CAACA,CAACA;YAC/EA,CAACA;QACFA,CAACA;IAEFA,CAACA;IAnLDL;;;OAGGA;IACWA,4CAA0BA,GAAUA,0BAA0BA,CAACA;IAE7EA;;;OAGGA;IACWA,0CAAwBA,GAAUA,wBAAwBA,CAACA;IA0K1EA,wBAACA;AAADA,CAxMA,AAwMCA,EAxM+B,gBAAgB,EAwM/C;AAED,AAA2B,iBAAlB,iBAAiB,CAAC","file":"animators/nodes/ParticleColorNode.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import ColorTransform\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/ColorTransform\");\nimport Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\n\nimport ParticleAnimationSet\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimationSet\");\nimport ParticleProperties\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleProperties\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleNodeBase\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleNodeBase\");\nimport ParticleColorState\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleColorState\");\n\n/**\n * A particle animation node used to control the color variation of a particle over time.\n */\nclass ParticleColorNode extends ParticleNodeBase\n{\n\t//default values used when creating states\n\t/** @private */\n\tpublic _iUsesMultiplier:boolean;\n\t/** @private */\n\tpublic _iUsesOffset:boolean;\n\t/** @private */\n\tpublic _iUsesCycle:boolean;\n\t/** @private */\n\tpublic _iUsesPhase:boolean;\n\t/** @private */\n\tpublic _iStartColor:ColorTransform;\n\t/** @private */\n\tpublic _iEndColor:ColorTransform;\n\t/** @private */\n\tpublic _iCycleDuration:number;\n\t/** @private */\n\tpublic _iCyclePhase:number;\n\n\t/**\n\t * Reference for color node properties on a single particle (when in local property mode).\n\t * Expects a <code>ColorTransform</code> object representing the start color transform applied to the particle.\n\t */\n\tpublic static COLOR_START_COLORTRANSFORM:string = \"ColorStartColorTransform\";\n\n\t/**\n\t * Reference for color node properties on a single particle (when in local property mode).\n\t * Expects a <code>ColorTransform</code> object representing the end color transform applied to the particle.\n\t */\n\tpublic static COLOR_END_COLORTRANSFORM:string = \"ColorEndColorTransform\";\n\n\t/**\n\t * Creates a new <code>ParticleColorNode</code>\n\t *\n\t * @param               mode            Defines whether the mode of operation acts on local properties of a particle or global properties of the node.\n\t * @param    [optional] usesMultiplier  Defines whether the node uses multiplier data in the shader for its color transformations. Defaults to true.\n\t * @param    [optional] usesOffset      Defines whether the node uses offset data in the shader for its color transformations. Defaults to true.\n\t * @param    [optional] usesCycle       Defines whether the node uses the <code>cycleDuration</code> property in the shader to calculate the period of the animation independent of particle duration. Defaults to false.\n\t * @param    [optional] usesPhase       Defines whether the node uses the <code>cyclePhase</code> property in the shader to calculate a starting offset to the cycle rotation of the particle. Defaults to false.\n\t * @param    [optional] startColor      Defines the default start color transform of the node, when in global mode.\n\t * @param    [optional] endColor        Defines the default end color transform of the node, when in global mode.\n\t * @param    [optional] cycleDuration   Defines the duration of the animation in seconds, used as a period independent of particle duration when in global mode. Defaults to 1.\n\t * @param    [optional] cyclePhase      Defines the phase of the cycle in degrees, used as the starting offset of the cycle when in global mode. Defaults to 0.\n\t */\n\tconstructor(mode:number /*uint*/, usesMultiplier:boolean = true, usesOffset:boolean = true, usesCycle:boolean = false, usesPhase:boolean = false, startColor:ColorTransform = null, endColor:ColorTransform = null, cycleDuration:number = 1, cyclePhase:number = 0)\n\t{\n\t\tsuper(\"ParticleColor\", mode, (usesMultiplier && usesOffset)? 16 : 8, ParticleAnimationSet.COLOR_PRIORITY);\n\n\t\tthis._pStateClass = ParticleColorState;\n\n\t\tthis._iUsesMultiplier = usesMultiplier;\n\t\tthis._iUsesOffset = usesOffset;\n\t\tthis._iUsesCycle = usesCycle;\n\t\tthis._iUsesPhase = usesPhase;\n\n\t\tthis._iStartColor = startColor || new ColorTransform();\n\t\tthis._iEndColor = endColor || new ColorTransform();\n\t\tthis._iCycleDuration = cycleDuration;\n\t\tthis._iCyclePhase = cyclePhase;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string\n\t{\n\t\tvar code:string = \"\";\n\t\tif (animationRegisterCache.needFragmentAnimation) {\n\t\t\tvar temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\n\t\t\tif (this._iUsesCycle) {\n\t\t\t\tvar cycleConst:ShaderRegisterElement = animationRegisterCache.getFreeVertexConstant();\n\t\t\t\tanimationRegisterCache.setRegisterIndex(this, ParticleColorState.CYCLE_INDEX, cycleConst.index);\n\n\t\t\t\tanimationRegisterCache.addVertexTempUsages(temp, 1);\n\t\t\t\tvar sin:ShaderRegisterElement = animationRegisterCache.getFreeVertexSingleTemp();\n\t\t\t\tanimationRegisterCache.removeVertexTempUsage(temp);\n\n\t\t\t\tcode += \"mul \" + sin + \",\" + animationRegisterCache.vertexTime + \",\" + cycleConst + \".x\\n\";\n\n\t\t\t\tif (this._iUsesPhase)\n\t\t\t\t\tcode += \"add \" + sin + \",\" + sin + \",\" + cycleConst + \".y\\n\";\n\n\t\t\t\tcode += \"sin \" + sin + \",\" + sin + \"\\n\";\n\t\t\t}\n\n\t\t\tif (this._iUsesMultiplier) {\n\t\t\t\tvar startMultiplierValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();\n\t\t\t\tvar deltaMultiplierValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();\n\n\t\t\t\tanimationRegisterCache.setRegisterIndex(this, ParticleColorState.START_MULTIPLIER_INDEX, startMultiplierValue.index);\n\t\t\t\tanimationRegisterCache.setRegisterIndex(this, ParticleColorState.DELTA_MULTIPLIER_INDEX, deltaMultiplierValue.index);\n\n\t\t\t\tcode += \"mul \" + temp + \",\" + deltaMultiplierValue + \",\" + (this._iUsesCycle? sin : animationRegisterCache.vertexLife) + \"\\n\";\n\t\t\t\tcode += \"add \" + temp + \",\" + temp + \",\" + startMultiplierValue + \"\\n\";\n\t\t\t\tcode += \"mul \" + animationRegisterCache.colorMulTarget + \",\" + temp + \",\" + animationRegisterCache.colorMulTarget + \"\\n\";\n\t\t\t}\n\n\t\t\tif (this._iUsesOffset) {\n\t\t\t\tvar startOffsetValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.LOCAL_STATIC)? animationRegisterCache.getFreeVertexAttribute() : animationRegisterCache.getFreeVertexConstant();\n\t\t\t\tvar deltaOffsetValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.LOCAL_STATIC)? animationRegisterCache.getFreeVertexAttribute() : animationRegisterCache.getFreeVertexConstant();\n\n\t\t\t\tanimationRegisterCache.setRegisterIndex(this, ParticleColorState.START_OFFSET_INDEX, startOffsetValue.index);\n\t\t\t\tanimationRegisterCache.setRegisterIndex(this, ParticleColorState.DELTA_OFFSET_INDEX, deltaOffsetValue.index);\n\n\t\t\t\tcode += \"mul \" + temp + \",\" + deltaOffsetValue + \",\" + (this._iUsesCycle? sin : animationRegisterCache.vertexLife) + \"\\n\";\n\t\t\t\tcode += \"add \" + temp + \",\" + temp + \",\" + startOffsetValue + \"\\n\";\n\t\t\t\tcode += \"add \" + animationRegisterCache.colorAddTarget + \",\" + temp + \",\" + animationRegisterCache.colorAddTarget + \"\\n\";\n\t\t\t}\n\t\t}\n\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAnimationState(animator:AnimatorBase):ParticleColorState\n\t{\n\t\treturn <ParticleColorState> animator.getAnimationState(this);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _iProcessAnimationSetting(particleAnimationSet:ParticleAnimationSet)\n\t{\n\t\tif (this._iUsesMultiplier)\n\t\t\tparticleAnimationSet.hasColorMulNode = true;\n\t\tif (this._iUsesOffset)\n\t\t\tparticleAnimationSet.hasColorAddNode = true;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _iGeneratePropertyOfOneParticle(param:ParticleProperties)\n\t{\n\t\tvar startColor:ColorTransform = param[ParticleColorNode.COLOR_START_COLORTRANSFORM];\n\t\tif (!startColor)\n\t\t\tthrow(new Error(\"there is no \" + ParticleColorNode.COLOR_START_COLORTRANSFORM + \" in param!\"));\n\n\t\tvar endColor:ColorTransform = param[ParticleColorNode.COLOR_END_COLORTRANSFORM];\n\t\tif (!endColor)\n\t\t\tthrow(new Error(\"there is no \" + ParticleColorNode.COLOR_END_COLORTRANSFORM + \" in param!\"));\n\n\t\tvar i:number /*uint*/ = 0;\n\n\t\tif (!this._iUsesCycle) {\n\t\t\t//multiplier\n\t\t\tif (this._iUsesMultiplier) {\n\t\t\t\tthis._pOneData[i++] = startColor.redMultiplier;\n\t\t\t\tthis._pOneData[i++] = startColor.greenMultiplier;\n\t\t\t\tthis._pOneData[i++] = startColor.blueMultiplier;\n\t\t\t\tthis._pOneData[i++] = startColor.alphaMultiplier;\n\t\t\t\tthis._pOneData[i++] = endColor.redMultiplier - startColor.redMultiplier;\n\t\t\t\tthis._pOneData[i++] = endColor.greenMultiplier - startColor.greenMultiplier;\n\t\t\t\tthis._pOneData[i++] = endColor.blueMultiplier - startColor.blueMultiplier;\n\t\t\t\tthis._pOneData[i++] = endColor.alphaMultiplier - startColor.alphaMultiplier;\n\t\t\t}\n\n\t\t\t//offset\n\t\t\tif (this._iUsesOffset) {\n\t\t\t\tthis._pOneData[i++] = startColor.redOffset/255;\n\t\t\t\tthis._pOneData[i++] = startColor.greenOffset/255;\n\t\t\t\tthis._pOneData[i++] = startColor.blueOffset/255;\n\t\t\t\tthis._pOneData[i++] = startColor.alphaOffset/255;\n\t\t\t\tthis._pOneData[i++] = (endColor.redOffset - startColor.redOffset)/255;\n\t\t\t\tthis._pOneData[i++] = (endColor.greenOffset - startColor.greenOffset)/255;\n\t\t\t\tthis._pOneData[i++] = (endColor.blueOffset - startColor.blueOffset)/255;\n\t\t\t\tthis._pOneData[i++] = (endColor.alphaOffset - startColor.alphaOffset)/255;\n\t\t\t}\n\t\t} else {\n\t\t\t//multiplier\n\t\t\tif (this._iUsesMultiplier) {\n\t\t\t\tthis._pOneData[i++] = (startColor.redMultiplier + endColor.redMultiplier)/2;\n\t\t\t\tthis._pOneData[i++] = (startColor.greenMultiplier + endColor.greenMultiplier)/2;\n\t\t\t\tthis._pOneData[i++] = (startColor.blueMultiplier + endColor.blueMultiplier)/2;\n\t\t\t\tthis._pOneData[i++] = (startColor.alphaMultiplier + endColor.alphaMultiplier)/2;\n\t\t\t\tthis._pOneData[i++] = (startColor.redMultiplier - endColor.redMultiplier)/2;\n\t\t\t\tthis._pOneData[i++] = (startColor.greenMultiplier - endColor.greenMultiplier)/2;\n\t\t\t\tthis._pOneData[i++] = (startColor.blueMultiplier - endColor.blueMultiplier)/2;\n\t\t\t\tthis._pOneData[i++] = (startColor.alphaMultiplier - endColor.alphaMultiplier)/2;\n\t\t\t}\n\n\t\t\t//offset\n\t\t\tif (this._iUsesOffset) {\n\t\t\t\tthis._pOneData[i++] = (startColor.redOffset + endColor.redOffset)/(255*2);\n\t\t\t\tthis._pOneData[i++] = (startColor.greenOffset + endColor.greenOffset)/(255*2);\n\t\t\t\tthis._pOneData[i++] = (startColor.blueOffset + endColor.blueOffset)/(255*2);\n\t\t\t\tthis._pOneData[i++] = (startColor.alphaOffset + endColor.alphaOffset)/(255*2);\n\t\t\t\tthis._pOneData[i++] = (startColor.redOffset - endColor.redOffset)/(255*2);\n\t\t\t\tthis._pOneData[i++] = (startColor.greenOffset - endColor.greenOffset)/(255*2);\n\t\t\t\tthis._pOneData[i++] = (startColor.blueOffset - endColor.blueOffset)/(255*2);\n\t\t\t\tthis._pOneData[i++] = (startColor.alphaOffset - endColor.alphaOffset)/(255*2);\n\t\t\t}\n\t\t}\n\n\t}\n}\n\nexport = ParticleColorNode;"]}
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleColorNode.ts b/lib/animators/nodes/ParticleColorNode.ts
new file mode 100644
index 000000000..eb792beec
--- /dev/null
+++ b/lib/animators/nodes/ParticleColorNode.ts
@@ -0,0 +1,220 @@
+import ColorTransform = require("awayjs-core/lib/core/geom/ColorTransform");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+
+import ParticleAnimationSet = require("awayjs-renderergl/lib/animators/ParticleAnimationSet");
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleColorState = require("awayjs-renderergl/lib/animators/states/ParticleColorState");
+
+/**
+ * A particle animation node used to control the color variation of a particle over time.
+ */
+class ParticleColorNode extends ParticleNodeBase
+{
+ //default values used when creating states
+ /** @private */
+ public _iUsesMultiplier:boolean;
+ /** @private */
+ public _iUsesOffset:boolean;
+ /** @private */
+ public _iUsesCycle:boolean;
+ /** @private */
+ public _iUsesPhase:boolean;
+ /** @private */
+ public _iStartColor:ColorTransform;
+ /** @private */
+ public _iEndColor:ColorTransform;
+ /** @private */
+ public _iCycleDuration:number;
+ /** @private */
+ public _iCyclePhase:number;
+
+ /**
+ * Reference for color node properties on a single particle (when in local property mode).
+ * Expects a ColorTransform
object representing the start color transform applied to the particle.
+ */
+ public static COLOR_START_COLORTRANSFORM:string = "ColorStartColorTransform";
+
+ /**
+ * Reference for color node properties on a single particle (when in local property mode).
+ * Expects a ColorTransform
object representing the end color transform applied to the particle.
+ */
+ public static COLOR_END_COLORTRANSFORM:string = "ColorEndColorTransform";
+
+ /**
+ * Creates a new ParticleColorNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] usesMultiplier Defines whether the node uses multiplier data in the shader for its color transformations. Defaults to true.
+ * @param [optional] usesOffset Defines whether the node uses offset data in the shader for its color transformations. Defaults to true.
+ * @param [optional] usesCycle Defines whether the node uses the cycleDuration
property in the shader to calculate the period of the animation independent of particle duration. Defaults to false.
+ * @param [optional] usesPhase Defines whether the node uses the cyclePhase
property in the shader to calculate a starting offset to the cycle rotation of the particle. Defaults to false.
+ * @param [optional] startColor Defines the default start color transform of the node, when in global mode.
+ * @param [optional] endColor Defines the default end color transform of the node, when in global mode.
+ * @param [optional] cycleDuration Defines the duration of the animation in seconds, used as a period independent of particle duration when in global mode. Defaults to 1.
+ * @param [optional] cyclePhase Defines the phase of the cycle in degrees, used as the starting offset of the cycle when in global mode. Defaults to 0.
+ */
+ constructor(mode:number /*uint*/, usesMultiplier:boolean = true, usesOffset:boolean = true, usesCycle:boolean = false, usesPhase:boolean = false, startColor:ColorTransform = null, endColor:ColorTransform = null, cycleDuration:number = 1, cyclePhase:number = 0)
+ {
+ super("ParticleColor", mode, (usesMultiplier && usesOffset)? 16 : 8, ParticleAnimationSet.COLOR_PRIORITY);
+
+ this._pStateClass = ParticleColorState;
+
+ this._iUsesMultiplier = usesMultiplier;
+ this._iUsesOffset = usesOffset;
+ this._iUsesCycle = usesCycle;
+ this._iUsesPhase = usesPhase;
+
+ this._iStartColor = startColor || new ColorTransform();
+ this._iEndColor = endColor || new ColorTransform();
+ this._iCycleDuration = cycleDuration;
+ this._iCyclePhase = cyclePhase;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ var code:string = "";
+ if (animationRegisterCache.needFragmentAnimation) {
+ var temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+
+ if (this._iUsesCycle) {
+ var cycleConst:ShaderRegisterElement = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleColorState.CYCLE_INDEX, cycleConst.index);
+
+ animationRegisterCache.addVertexTempUsages(temp, 1);
+ var sin:ShaderRegisterElement = animationRegisterCache.getFreeVertexSingleTemp();
+ animationRegisterCache.removeVertexTempUsage(temp);
+
+ code += "mul " + sin + "," + animationRegisterCache.vertexTime + "," + cycleConst + ".x\n";
+
+ if (this._iUsesPhase)
+ code += "add " + sin + "," + sin + "," + cycleConst + ".y\n";
+
+ code += "sin " + sin + "," + sin + "\n";
+ }
+
+ if (this._iUsesMultiplier) {
+ var startMultiplierValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ var deltaMultiplierValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+
+ animationRegisterCache.setRegisterIndex(this, ParticleColorState.START_MULTIPLIER_INDEX, startMultiplierValue.index);
+ animationRegisterCache.setRegisterIndex(this, ParticleColorState.DELTA_MULTIPLIER_INDEX, deltaMultiplierValue.index);
+
+ code += "mul " + temp + "," + deltaMultiplierValue + "," + (this._iUsesCycle? sin : animationRegisterCache.vertexLife) + "\n";
+ code += "add " + temp + "," + temp + "," + startMultiplierValue + "\n";
+ code += "mul " + animationRegisterCache.colorMulTarget + "," + temp + "," + animationRegisterCache.colorMulTarget + "\n";
+ }
+
+ if (this._iUsesOffset) {
+ var startOffsetValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.LOCAL_STATIC)? animationRegisterCache.getFreeVertexAttribute() : animationRegisterCache.getFreeVertexConstant();
+ var deltaOffsetValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.LOCAL_STATIC)? animationRegisterCache.getFreeVertexAttribute() : animationRegisterCache.getFreeVertexConstant();
+
+ animationRegisterCache.setRegisterIndex(this, ParticleColorState.START_OFFSET_INDEX, startOffsetValue.index);
+ animationRegisterCache.setRegisterIndex(this, ParticleColorState.DELTA_OFFSET_INDEX, deltaOffsetValue.index);
+
+ code += "mul " + temp + "," + deltaOffsetValue + "," + (this._iUsesCycle? sin : animationRegisterCache.vertexLife) + "\n";
+ code += "add " + temp + "," + temp + "," + startOffsetValue + "\n";
+ code += "add " + animationRegisterCache.colorAddTarget + "," + temp + "," + animationRegisterCache.colorAddTarget + "\n";
+ }
+ }
+
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):ParticleColorState
+ {
+ return animator.getAnimationState(this);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iProcessAnimationSetting(particleAnimationSet:ParticleAnimationSet)
+ {
+ if (this._iUsesMultiplier)
+ particleAnimationSet.hasColorMulNode = true;
+ if (this._iUsesOffset)
+ particleAnimationSet.hasColorAddNode = true;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iGeneratePropertyOfOneParticle(param:ParticleProperties)
+ {
+ var startColor:ColorTransform = param[ParticleColorNode.COLOR_START_COLORTRANSFORM];
+ if (!startColor)
+ throw(new Error("there is no " + ParticleColorNode.COLOR_START_COLORTRANSFORM + " in param!"));
+
+ var endColor:ColorTransform = param[ParticleColorNode.COLOR_END_COLORTRANSFORM];
+ if (!endColor)
+ throw(new Error("there is no " + ParticleColorNode.COLOR_END_COLORTRANSFORM + " in param!"));
+
+ var i:number /*uint*/ = 0;
+
+ if (!this._iUsesCycle) {
+ //multiplier
+ if (this._iUsesMultiplier) {
+ this._pOneData[i++] = startColor.redMultiplier;
+ this._pOneData[i++] = startColor.greenMultiplier;
+ this._pOneData[i++] = startColor.blueMultiplier;
+ this._pOneData[i++] = startColor.alphaMultiplier;
+ this._pOneData[i++] = endColor.redMultiplier - startColor.redMultiplier;
+ this._pOneData[i++] = endColor.greenMultiplier - startColor.greenMultiplier;
+ this._pOneData[i++] = endColor.blueMultiplier - startColor.blueMultiplier;
+ this._pOneData[i++] = endColor.alphaMultiplier - startColor.alphaMultiplier;
+ }
+
+ //offset
+ if (this._iUsesOffset) {
+ this._pOneData[i++] = startColor.redOffset/255;
+ this._pOneData[i++] = startColor.greenOffset/255;
+ this._pOneData[i++] = startColor.blueOffset/255;
+ this._pOneData[i++] = startColor.alphaOffset/255;
+ this._pOneData[i++] = (endColor.redOffset - startColor.redOffset)/255;
+ this._pOneData[i++] = (endColor.greenOffset - startColor.greenOffset)/255;
+ this._pOneData[i++] = (endColor.blueOffset - startColor.blueOffset)/255;
+ this._pOneData[i++] = (endColor.alphaOffset - startColor.alphaOffset)/255;
+ }
+ } else {
+ //multiplier
+ if (this._iUsesMultiplier) {
+ this._pOneData[i++] = (startColor.redMultiplier + endColor.redMultiplier)/2;
+ this._pOneData[i++] = (startColor.greenMultiplier + endColor.greenMultiplier)/2;
+ this._pOneData[i++] = (startColor.blueMultiplier + endColor.blueMultiplier)/2;
+ this._pOneData[i++] = (startColor.alphaMultiplier + endColor.alphaMultiplier)/2;
+ this._pOneData[i++] = (startColor.redMultiplier - endColor.redMultiplier)/2;
+ this._pOneData[i++] = (startColor.greenMultiplier - endColor.greenMultiplier)/2;
+ this._pOneData[i++] = (startColor.blueMultiplier - endColor.blueMultiplier)/2;
+ this._pOneData[i++] = (startColor.alphaMultiplier - endColor.alphaMultiplier)/2;
+ }
+
+ //offset
+ if (this._iUsesOffset) {
+ this._pOneData[i++] = (startColor.redOffset + endColor.redOffset)/(255*2);
+ this._pOneData[i++] = (startColor.greenOffset + endColor.greenOffset)/(255*2);
+ this._pOneData[i++] = (startColor.blueOffset + endColor.blueOffset)/(255*2);
+ this._pOneData[i++] = (startColor.alphaOffset + endColor.alphaOffset)/(255*2);
+ this._pOneData[i++] = (startColor.redOffset - endColor.redOffset)/(255*2);
+ this._pOneData[i++] = (startColor.greenOffset - endColor.greenOffset)/(255*2);
+ this._pOneData[i++] = (startColor.blueOffset - endColor.blueOffset)/(255*2);
+ this._pOneData[i++] = (startColor.alphaOffset - endColor.alphaOffset)/(255*2);
+ }
+ }
+
+ }
+}
+
+export = ParticleColorNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleFollowNode.js b/lib/animators/nodes/ParticleFollowNode.js
new file mode 100755
index 000000000..ad964cac1
--- /dev/null
+++ b/lib/animators/nodes/ParticleFollowNode.js
@@ -0,0 +1,127 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var ParticleAnimationSet = require("awayjs-renderergl/lib/animators/ParticleAnimationSet");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+var ParticleFollowState = require("awayjs-renderergl/lib/animators/states/ParticleFollowState");
+/**
+ * A particle animation node used to create a follow behaviour on a particle system.
+ */
+var ParticleFollowNode = (function (_super) {
+ __extends(ParticleFollowNode, _super);
+ /**
+ * Creates a new ParticleFollowNode
+ *
+ * @param [optional] usesPosition Defines wehether the individual particle reacts to the position of the target.
+ * @param [optional] usesRotation Defines wehether the individual particle reacts to the rotation of the target.
+ * @param [optional] smooth Defines wehether the state calculate the interpolated value.
+ */
+ function ParticleFollowNode(usesPosition, usesRotation, smooth) {
+ if (usesPosition === void 0) { usesPosition = true; }
+ if (usesRotation === void 0) { usesRotation = true; }
+ if (smooth === void 0) { smooth = false; }
+ _super.call(this, "ParticleFollow", ParticlePropertiesMode.LOCAL_DYNAMIC, (usesPosition && usesRotation) ? 6 : 3, ParticleAnimationSet.POST_PRIORITY);
+ this._pStateClass = ParticleFollowState;
+ this._iUsesPosition = usesPosition;
+ this._iUsesRotation = usesRotation;
+ this._iSmooth = smooth;
+ }
+ /**
+ * @inheritDoc
+ */
+ ParticleFollowNode.prototype.getAGALVertexCode = function (shaderObject, animationRegisterCache) {
+ //TODO: use Quaternion to implement this function
+ var code = "";
+ if (this._iUsesRotation) {
+ var rotationAttribute = animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleFollowState.FOLLOW_ROTATION_INDEX, rotationAttribute.index);
+ var temp1 = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp1, 1);
+ var temp2 = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp2, 1);
+ var temp3 = animationRegisterCache.getFreeVertexVectorTemp();
+ var temp4;
+ if (animationRegisterCache.hasBillboard) {
+ animationRegisterCache.addVertexTempUsages(temp3, 1);
+ temp4 = animationRegisterCache.getFreeVertexVectorTemp();
+ }
+ animationRegisterCache.removeVertexTempUsage(temp1);
+ animationRegisterCache.removeVertexTempUsage(temp2);
+ if (animationRegisterCache.hasBillboard)
+ animationRegisterCache.removeVertexTempUsage(temp3);
+ var len = animationRegisterCache.rotationRegisters.length;
+ var i /*int*/;
+ //x axis
+ code += "mov " + temp1 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp1 + ".x," + animationRegisterCache.vertexOneConst + "\n";
+ code += "mov " + temp3 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "sin " + temp3 + ".y," + rotationAttribute + ".x\n";
+ code += "cos " + temp3 + ".z," + rotationAttribute + ".x\n";
+ code += "mov " + temp2 + ".x," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp2 + ".y," + temp3 + ".z\n";
+ code += "neg " + temp2 + ".z," + temp3 + ".y\n";
+ if (animationRegisterCache.hasBillboard)
+ code += "m33 " + temp4 + ".xyz," + animationRegisterCache.positionTarget + ".xyz," + temp1 + "\n";
+ else {
+ code += "m33 " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz," + temp1 + "\n";
+ for (i = 0; i < len; i++)
+ code += "m33 " + animationRegisterCache.rotationRegisters[i] + ".xyz," + animationRegisterCache.rotationRegisters[i] + "," + temp1 + "\n";
+ }
+ //y axis
+ code += "mov " + temp1 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "cos " + temp1 + ".x," + rotationAttribute + ".y\n";
+ code += "sin " + temp1 + ".z," + rotationAttribute + ".y\n";
+ code += "mov " + temp2 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp2 + ".y," + animationRegisterCache.vertexOneConst + "\n";
+ code += "mov " + temp3 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "neg " + temp3 + ".x," + temp1 + ".z\n";
+ code += "mov " + temp3 + ".z," + temp1 + ".x\n";
+ if (animationRegisterCache.hasBillboard)
+ code += "m33 " + temp4 + ".xyz," + temp4 + ".xyz," + temp1 + "\n";
+ else {
+ code += "m33 " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz," + temp1 + "\n";
+ for (i = 0; i < len; i++)
+ code += "m33 " + animationRegisterCache.rotationRegisters[i] + ".xyz," + animationRegisterCache.rotationRegisters[i] + "," + temp1 + "\n";
+ }
+ //z axis
+ code += "mov " + temp2 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "sin " + temp2 + ".x," + rotationAttribute + ".z\n";
+ code += "cos " + temp2 + ".y," + rotationAttribute + ".z\n";
+ code += "mov " + temp1 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp1 + ".x," + temp2 + ".y\n";
+ code += "neg " + temp1 + ".y," + temp2 + ".x\n";
+ code += "mov " + temp3 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp3 + ".z," + animationRegisterCache.vertexOneConst + "\n";
+ if (animationRegisterCache.hasBillboard) {
+ code += "m33 " + temp4 + ".xyz," + temp4 + ".xyz," + temp1 + "\n";
+ code += "sub " + temp4 + ".xyz," + temp4 + ".xyz," + animationRegisterCache.positionTarget + ".xyz\n";
+ code += "add " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + temp4 + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz\n";
+ }
+ else {
+ code += "m33 " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz," + temp1 + "\n";
+ for (i = 0; i < len; i++)
+ code += "m33 " + animationRegisterCache.rotationRegisters[i] + ".xyz," + animationRegisterCache.rotationRegisters[i] + "," + temp1 + "\n";
+ }
+ }
+ if (this._iUsesPosition) {
+ var positionAttribute = animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleFollowState.FOLLOW_POSITION_INDEX, positionAttribute.index);
+ code += "add " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + positionAttribute + "," + animationRegisterCache.scaleAndRotateTarget + ".xyz\n";
+ }
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleFollowNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ return ParticleFollowNode;
+})(ParticleNodeBase);
+module.exports = ParticleFollowNode;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/nodes/particlefollownode.ts"],"names":["ParticleFollowNode","ParticleFollowNode.constructor","ParticleFollowNode.getAGALVertexCode","ParticleFollowNode.getAnimationState"],"mappings":"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","file":"animators/nodes/ParticleFollowNode.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\n\nimport ParticleAnimationSet\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimationSet\");\nimport ParticleProperties\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleProperties\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleNodeBase\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleNodeBase\");\nimport ParticleFollowState\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleFollowState\");\n\n/**\n * A particle animation node used to create a follow behaviour on a particle system.\n */\nclass ParticleFollowNode extends ParticleNodeBase\n{\n\t/** @private */\n\tpublic _iUsesPosition:boolean;\n\n\t/** @private */\n\tpublic _iUsesRotation:boolean;\n\n\t/** @private */\n\tpublic _iSmooth:boolean;\n\n\t/**\n\t * Creates a new <code>ParticleFollowNode</code>\n\t *\n\t * @param    [optional] usesPosition     Defines wehether the individual particle reacts to the position of the target.\n\t * @param    [optional] usesRotation     Defines wehether the individual particle reacts to the rotation of the target.\n\t * @param    [optional] smooth     Defines wehether the state calculate the interpolated value.\n\t */\n\tconstructor(usesPosition:boolean = true, usesRotation:boolean = true, smooth:boolean = false)\n\t{\n\t\tsuper(\"ParticleFollow\", ParticlePropertiesMode.LOCAL_DYNAMIC, (usesPosition && usesRotation)? 6 : 3, ParticleAnimationSet.POST_PRIORITY);\n\n\t\tthis._pStateClass = ParticleFollowState;\n\n\t\tthis._iUsesPosition = usesPosition;\n\t\tthis._iUsesRotation = usesRotation;\n\t\tthis._iSmooth = smooth;\n\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string\n\t{\n\t\t//TODO: use Quaternion to implement this function\n\t\tvar code:string = \"\";\n\t\tif (this._iUsesRotation) {\n\t\t\tvar rotationAttribute:ShaderRegisterElement = animationRegisterCache.getFreeVertexAttribute();\n\t\t\tanimationRegisterCache.setRegisterIndex(this, ParticleFollowState.FOLLOW_ROTATION_INDEX, rotationAttribute.index);\n\n\t\t\tvar temp1:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\t\tanimationRegisterCache.addVertexTempUsages(temp1, 1);\n\t\t\tvar temp2:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\t\tanimationRegisterCache.addVertexTempUsages(temp2, 1);\n\t\t\tvar temp3:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\n\t\t\tvar temp4:ShaderRegisterElement;\n\t\t\tif (animationRegisterCache.hasBillboard) {\n\t\t\t\tanimationRegisterCache.addVertexTempUsages(temp3, 1);\n\t\t\t\ttemp4 = animationRegisterCache.getFreeVertexVectorTemp();\n\t\t\t}\n\n\t\t\tanimationRegisterCache.removeVertexTempUsage(temp1);\n\t\t\tanimationRegisterCache.removeVertexTempUsage(temp2);\n\t\t\tif (animationRegisterCache.hasBillboard)\n\t\t\t\tanimationRegisterCache.removeVertexTempUsage(temp3);\n\n\t\t\tvar len:number /*int*/ = animationRegisterCache.rotationRegisters.length;\n\t\t\tvar i:number /*int*/;\n\n\t\t\t//x axis\n\t\t\tcode += \"mov \" + temp1 + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"mov \" + temp1 + \".x,\" + animationRegisterCache.vertexOneConst + \"\\n\";\n\t\t\tcode += \"mov \" + temp3 + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"sin \" + temp3 + \".y,\" + rotationAttribute + \".x\\n\";\n\t\t\tcode += \"cos \" + temp3 + \".z,\" + rotationAttribute + \".x\\n\";\n\t\t\tcode += \"mov \" + temp2 + \".x,\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"mov \" + temp2 + \".y,\" + temp3 + \".z\\n\";\n\t\t\tcode += \"neg \" + temp2 + \".z,\" + temp3 + \".y\\n\";\n\n\t\t\tif (animationRegisterCache.hasBillboard)\n\t\t\t\tcode += \"m33 \" + temp4 + \".xyz,\" + animationRegisterCache.positionTarget + \".xyz,\" + temp1 + \"\\n\";\n\t\t\telse {\n\t\t\t\tcode += \"m33 \" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + temp1 + \"\\n\";\n\t\t\t\tfor (i = 0; i < len; i++)\n\t\t\t\t\tcode += \"m33 \" + animationRegisterCache.rotationRegisters[i] + \".xyz,\" + animationRegisterCache.rotationRegisters[i] + \",\" + temp1 + \"\\n\";\n\t\t\t}\n\n\t\t\t//y axis\n\t\t\tcode += \"mov \" + temp1 + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"cos \" + temp1 + \".x,\" + rotationAttribute + \".y\\n\";\n\t\t\tcode += \"sin \" + temp1 + \".z,\" + rotationAttribute + \".y\\n\";\n\t\t\tcode += \"mov \" + temp2 + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"mov \" + temp2 + \".y,\" + animationRegisterCache.vertexOneConst + \"\\n\";\n\t\t\tcode += \"mov \" + temp3 + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"neg \" + temp3 + \".x,\" + temp1 + \".z\\n\";\n\t\t\tcode += \"mov \" + temp3 + \".z,\" + temp1 + \".x\\n\";\n\n\t\t\tif (animationRegisterCache.hasBillboard)\n\t\t\t\tcode += \"m33 \" + temp4 + \".xyz,\" + temp4 + \".xyz,\" + temp1 + \"\\n\";\n\t\t\telse {\n\t\t\t\tcode += \"m33 \" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + temp1 + \"\\n\";\n\t\t\t\tfor (i = 0; i < len; i++)\n\t\t\t\t\tcode += \"m33 \" + animationRegisterCache.rotationRegisters[i] + \".xyz,\" + animationRegisterCache.rotationRegisters[i] + \",\" + temp1 + \"\\n\";\n\t\t\t}\n\n\t\t\t//z axis\n\t\t\tcode += \"mov \" + temp2 + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"sin \" + temp2 + \".x,\" + rotationAttribute + \".z\\n\";\n\t\t\tcode += \"cos \" + temp2 + \".y,\" + rotationAttribute + \".z\\n\";\n\t\t\tcode += \"mov \" + temp1 + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"mov \" + temp1 + \".x,\" + temp2 + \".y\\n\";\n\t\t\tcode += \"neg \" + temp1 + \".y,\" + temp2 + \".x\\n\";\n\t\t\tcode += \"mov \" + temp3 + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"mov \" + temp3 + \".z,\" + animationRegisterCache.vertexOneConst + \"\\n\";\n\n\t\t\tif (animationRegisterCache.hasBillboard) {\n\t\t\t\tcode += \"m33 \" + temp4 + \".xyz,\" + temp4 + \".xyz,\" + temp1 + \"\\n\";\n\t\t\t\tcode += \"sub \" + temp4 + \".xyz,\" + temp4 + \".xyz,\" + animationRegisterCache.positionTarget + \".xyz\\n\";\n\t\t\t\tcode += \"add \" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + temp4 + \".xyz,\" + animationRegisterCache.scaleAndRotateTarget + \".xyz\\n\";\n\t\t\t} else {\n\t\t\t\tcode += \"m33 \" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + temp1 + \"\\n\";\n\t\t\t\tfor (i = 0; i < len; i++)\n\t\t\t\t\tcode += \"m33 \" + animationRegisterCache.rotationRegisters[i] + \".xyz,\" + animationRegisterCache.rotationRegisters[i] + \",\" + temp1 + \"\\n\";\n\t\t\t}\n\n\t\t}\n\n\t\tif (this._iUsesPosition) {\n\t\t\tvar positionAttribute:ShaderRegisterElement = animationRegisterCache.getFreeVertexAttribute();\n\t\t\tanimationRegisterCache.setRegisterIndex(this, ParticleFollowState.FOLLOW_POSITION_INDEX, positionAttribute.index);\n\t\t\tcode += \"add \" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + positionAttribute + \",\" + animationRegisterCache.scaleAndRotateTarget + \".xyz\\n\";\n\t\t}\n\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAnimationState(animator:AnimatorBase):ParticleFollowState\n\t{\n\t\treturn <ParticleFollowState> animator.getAnimationState(this);\n\t}\n}\n\nexport = ParticleFollowNode;"]}
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleFollowNode.ts b/lib/animators/nodes/ParticleFollowNode.ts
new file mode 100644
index 000000000..c4cb793e8
--- /dev/null
+++ b/lib/animators/nodes/ParticleFollowNode.ts
@@ -0,0 +1,154 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+
+import ParticleAnimationSet = require("awayjs-renderergl/lib/animators/ParticleAnimationSet");
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleFollowState = require("awayjs-renderergl/lib/animators/states/ParticleFollowState");
+
+/**
+ * A particle animation node used to create a follow behaviour on a particle system.
+ */
+class ParticleFollowNode extends ParticleNodeBase
+{
+ /** @private */
+ public _iUsesPosition:boolean;
+
+ /** @private */
+ public _iUsesRotation:boolean;
+
+ /** @private */
+ public _iSmooth:boolean;
+
+ /**
+ * Creates a new ParticleFollowNode
+ *
+ * @param [optional] usesPosition Defines wehether the individual particle reacts to the position of the target.
+ * @param [optional] usesRotation Defines wehether the individual particle reacts to the rotation of the target.
+ * @param [optional] smooth Defines wehether the state calculate the interpolated value.
+ */
+ constructor(usesPosition:boolean = true, usesRotation:boolean = true, smooth:boolean = false)
+ {
+ super("ParticleFollow", ParticlePropertiesMode.LOCAL_DYNAMIC, (usesPosition && usesRotation)? 6 : 3, ParticleAnimationSet.POST_PRIORITY);
+
+ this._pStateClass = ParticleFollowState;
+
+ this._iUsesPosition = usesPosition;
+ this._iUsesRotation = usesRotation;
+ this._iSmooth = smooth;
+
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ //TODO: use Quaternion to implement this function
+ var code:string = "";
+ if (this._iUsesRotation) {
+ var rotationAttribute:ShaderRegisterElement = animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleFollowState.FOLLOW_ROTATION_INDEX, rotationAttribute.index);
+
+ var temp1:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp1, 1);
+ var temp2:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp2, 1);
+ var temp3:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+
+ var temp4:ShaderRegisterElement;
+ if (animationRegisterCache.hasBillboard) {
+ animationRegisterCache.addVertexTempUsages(temp3, 1);
+ temp4 = animationRegisterCache.getFreeVertexVectorTemp();
+ }
+
+ animationRegisterCache.removeVertexTempUsage(temp1);
+ animationRegisterCache.removeVertexTempUsage(temp2);
+ if (animationRegisterCache.hasBillboard)
+ animationRegisterCache.removeVertexTempUsage(temp3);
+
+ var len:number /*int*/ = animationRegisterCache.rotationRegisters.length;
+ var i:number /*int*/;
+
+ //x axis
+ code += "mov " + temp1 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp1 + ".x," + animationRegisterCache.vertexOneConst + "\n";
+ code += "mov " + temp3 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "sin " + temp3 + ".y," + rotationAttribute + ".x\n";
+ code += "cos " + temp3 + ".z," + rotationAttribute + ".x\n";
+ code += "mov " + temp2 + ".x," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp2 + ".y," + temp3 + ".z\n";
+ code += "neg " + temp2 + ".z," + temp3 + ".y\n";
+
+ if (animationRegisterCache.hasBillboard)
+ code += "m33 " + temp4 + ".xyz," + animationRegisterCache.positionTarget + ".xyz," + temp1 + "\n";
+ else {
+ code += "m33 " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz," + temp1 + "\n";
+ for (i = 0; i < len; i++)
+ code += "m33 " + animationRegisterCache.rotationRegisters[i] + ".xyz," + animationRegisterCache.rotationRegisters[i] + "," + temp1 + "\n";
+ }
+
+ //y axis
+ code += "mov " + temp1 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "cos " + temp1 + ".x," + rotationAttribute + ".y\n";
+ code += "sin " + temp1 + ".z," + rotationAttribute + ".y\n";
+ code += "mov " + temp2 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp2 + ".y," + animationRegisterCache.vertexOneConst + "\n";
+ code += "mov " + temp3 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "neg " + temp3 + ".x," + temp1 + ".z\n";
+ code += "mov " + temp3 + ".z," + temp1 + ".x\n";
+
+ if (animationRegisterCache.hasBillboard)
+ code += "m33 " + temp4 + ".xyz," + temp4 + ".xyz," + temp1 + "\n";
+ else {
+ code += "m33 " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz," + temp1 + "\n";
+ for (i = 0; i < len; i++)
+ code += "m33 " + animationRegisterCache.rotationRegisters[i] + ".xyz," + animationRegisterCache.rotationRegisters[i] + "," + temp1 + "\n";
+ }
+
+ //z axis
+ code += "mov " + temp2 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "sin " + temp2 + ".x," + rotationAttribute + ".z\n";
+ code += "cos " + temp2 + ".y," + rotationAttribute + ".z\n";
+ code += "mov " + temp1 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp1 + ".x," + temp2 + ".y\n";
+ code += "neg " + temp1 + ".y," + temp2 + ".x\n";
+ code += "mov " + temp3 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp3 + ".z," + animationRegisterCache.vertexOneConst + "\n";
+
+ if (animationRegisterCache.hasBillboard) {
+ code += "m33 " + temp4 + ".xyz," + temp4 + ".xyz," + temp1 + "\n";
+ code += "sub " + temp4 + ".xyz," + temp4 + ".xyz," + animationRegisterCache.positionTarget + ".xyz\n";
+ code += "add " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + temp4 + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz\n";
+ } else {
+ code += "m33 " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz," + temp1 + "\n";
+ for (i = 0; i < len; i++)
+ code += "m33 " + animationRegisterCache.rotationRegisters[i] + ".xyz," + animationRegisterCache.rotationRegisters[i] + "," + temp1 + "\n";
+ }
+
+ }
+
+ if (this._iUsesPosition) {
+ var positionAttribute:ShaderRegisterElement = animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleFollowState.FOLLOW_POSITION_INDEX, positionAttribute.index);
+ code += "add " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + positionAttribute + "," + animationRegisterCache.scaleAndRotateTarget + ".xyz\n";
+ }
+
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):ParticleFollowState
+ {
+ return animator.getAnimationState(this);
+ }
+}
+
+export = ParticleFollowNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleInitialColorNode.js b/lib/animators/nodes/ParticleInitialColorNode.js
new file mode 100755
index 000000000..fd68cbe37
--- /dev/null
+++ b/lib/animators/nodes/ParticleInitialColorNode.js
@@ -0,0 +1,87 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var ColorTransform = require("awayjs-core/lib/core/geom/ColorTransform");
+var ParticleAnimationSet = require("awayjs-renderergl/lib/animators/ParticleAnimationSet");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+var ParticleInitialColorState = require("awayjs-renderergl/lib/animators/states/ParticleInitialColorState");
+/**
+ *
+ */
+var ParticleInitialColorNode = (function (_super) {
+ __extends(ParticleInitialColorNode, _super);
+ function ParticleInitialColorNode(mode /*uint*/, usesMultiplier, usesOffset, initialColor) {
+ if (usesMultiplier === void 0) { usesMultiplier = true; }
+ if (usesOffset === void 0) { usesOffset = false; }
+ if (initialColor === void 0) { initialColor = null; }
+ _super.call(this, "ParticleInitialColor", mode, (usesMultiplier && usesOffset) ? 8 : 4, ParticleAnimationSet.COLOR_PRIORITY);
+ this._pStateClass = ParticleInitialColorState;
+ this._iUsesMultiplier = usesMultiplier;
+ this._iUsesOffset = usesOffset;
+ this._iInitialColor = initialColor || new ColorTransform();
+ }
+ /**
+ * @inheritDoc
+ */
+ ParticleInitialColorNode.prototype.getAGALVertexCode = function (shaderObject, animationRegisterCache) {
+ var code = "";
+ if (animationRegisterCache.needFragmentAnimation) {
+ if (this._iUsesMultiplier) {
+ var multiplierValue = (this._pMode == ParticlePropertiesMode.GLOBAL) ? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleInitialColorState.MULTIPLIER_INDEX, multiplierValue.index);
+ code += "mul " + animationRegisterCache.colorMulTarget + "," + multiplierValue + "," + animationRegisterCache.colorMulTarget + "\n";
+ }
+ if (this._iUsesOffset) {
+ var offsetValue = (this._pMode == ParticlePropertiesMode.LOCAL_STATIC) ? animationRegisterCache.getFreeVertexAttribute() : animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleInitialColorState.OFFSET_INDEX, offsetValue.index);
+ code += "add " + animationRegisterCache.colorAddTarget + "," + offsetValue + "," + animationRegisterCache.colorAddTarget + "\n";
+ }
+ }
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleInitialColorNode.prototype._iProcessAnimationSetting = function (particleAnimationSet) {
+ if (this._iUsesMultiplier)
+ particleAnimationSet.hasColorMulNode = true;
+ if (this._iUsesOffset)
+ particleAnimationSet.hasColorAddNode = true;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleInitialColorNode.prototype._iGeneratePropertyOfOneParticle = function (param) {
+ var initialColor = param[ParticleInitialColorNode.COLOR_INITIAL_COLORTRANSFORM];
+ if (!initialColor)
+ throw (new Error("there is no " + ParticleInitialColorNode.COLOR_INITIAL_COLORTRANSFORM + " in param!"));
+ var i = 0;
+ //multiplier
+ if (this._iUsesMultiplier) {
+ this._pOneData[i++] = initialColor.redMultiplier;
+ this._pOneData[i++] = initialColor.greenMultiplier;
+ this._pOneData[i++] = initialColor.blueMultiplier;
+ this._pOneData[i++] = initialColor.alphaMultiplier;
+ }
+ //offset
+ if (this._iUsesOffset) {
+ this._pOneData[i++] = initialColor.redOffset / 255;
+ this._pOneData[i++] = initialColor.greenOffset / 255;
+ this._pOneData[i++] = initialColor.blueOffset / 255;
+ this._pOneData[i++] = initialColor.alphaOffset / 255;
+ }
+ };
+ /**
+ * Reference for color node properties on a single particle (when in local property mode).
+ * Expects a ColorTransform
object representing the color transform applied to the particle.
+ */
+ ParticleInitialColorNode.COLOR_INITIAL_COLORTRANSFORM = "ColorInitialColorTransform";
+ return ParticleInitialColorNode;
+})(ParticleNodeBase);
+module.exports = ParticleInitialColorNode;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/nodes/particleinitialcolornode.ts"],"names":["ParticleInitialColorNode","ParticleInitialColorNode.constructor","ParticleInitialColorNode.getAGALVertexCode","ParticleInitialColorNode._iProcessAnimationSetting","ParticleInitialColorNode._iGeneratePropertyOfOneParticle"],"mappings":"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GAAGA,wBAAwBA,CAACA,4BAA4BA,GAAGA,YAAYA,CAACA,CAACA,CAACA;QAEzGA,IAAIA,CAACA,GAAmBA,CAACA,CAACA;QAE1BA,AACAA,YADYA;QACZA,EAAEA,CAACA,CAACA,IAAIA,CAACA,gBAAgBA,CAACA,CAACA,CAACA;YAC3BA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,YAAYA,CAACA,aAAaA,CAACA;YACjDA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,YAAYA,CAACA,eAAeA,CAACA;YACnDA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,YAAYA,CAACA,cAAcA,CAACA;YAClDA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,YAAYA,CAACA,eAAeA,CAACA;QACpDA,CAACA;QACDA,AACAA,QADQA;QACRA,EAAEA,CAACA,CAACA,IAAIA,CAACA,YAAYA,CAACA,CAACA,CAACA;YACvBA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,YAAYA,CAACA,SAASA,GAACA,GAAGA,CAACA;YACjDA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,YAAYA,CAACA,WAAWA,GAACA,GAAGA,CAACA;YACnDA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,YAAYA,CAACA,UAAUA,GAACA,GAAGA,CAACA;YAClDA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,CAACA,GAAGA,YAAYA,CAACA,WAAWA,GAACA,GAAGA,CAACA;QACpDA,CAACA;IAEFA,CAACA;IAhFDJ;;;OAGGA;IACWA,qDAA4BA,GAAUA,4BAA4BA,CAACA;IA8ElFA,+BAACA;AAADA,CA5FA,AA4FCA,EA5FsC,gBAAgB,EA4FtD;AAED,AAAkC,iBAAzB,wBAAwB,CAAC","file":"animators/nodes/ParticleInitialColorNode.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import ColorTransform\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/ColorTransform\");\nimport Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\n\nimport ParticleAnimationSet\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimationSet\");\nimport ParticleProperties\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleProperties\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleNodeBase\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleNodeBase\");\nimport ParticleInitialColorState\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleInitialColorState\");\n\n/**\n *\n */\nclass ParticleInitialColorNode extends ParticleNodeBase\n{\n\t//default values used when creating states\n\t/** @private */\n\tpublic _iUsesMultiplier:boolean;\n\t/** @private */\n\tpublic _iUsesOffset:boolean;\n\t/** @private */\n\tpublic _iInitialColor:ColorTransform;\n\n\t/**\n\t * Reference for color node properties on a single particle (when in local property mode).\n\t * Expects a <code>ColorTransform</code> object representing the color transform applied to the particle.\n\t */\n\tpublic static COLOR_INITIAL_COLORTRANSFORM:string = \"ColorInitialColorTransform\";\n\n\tconstructor(mode:number /*uint*/, usesMultiplier:boolean = true, usesOffset:boolean = false, initialColor:ColorTransform = null)\n\t{\n\t\tsuper(\"ParticleInitialColor\", mode, (usesMultiplier && usesOffset)? 8 : 4, ParticleAnimationSet.COLOR_PRIORITY);\n\n\t\tthis._pStateClass = ParticleInitialColorState;\n\n\t\tthis._iUsesMultiplier = usesMultiplier;\n\t\tthis._iUsesOffset = usesOffset;\n\t\tthis._iInitialColor = initialColor || new ColorTransform();\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string\n\t{\n\t\tvar code:string = \"\";\n\t\tif (animationRegisterCache.needFragmentAnimation) {\n\n\t\t\tif (this._iUsesMultiplier) {\n\t\t\t\tvar multiplierValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();\n\t\t\t\tanimationRegisterCache.setRegisterIndex(this, ParticleInitialColorState.MULTIPLIER_INDEX, multiplierValue.index);\n\n\t\t\t\tcode += \"mul \" + animationRegisterCache.colorMulTarget + \",\" + multiplierValue + \",\" + animationRegisterCache.colorMulTarget + \"\\n\";\n\t\t\t}\n\n\t\t\tif (this._iUsesOffset) {\n\t\t\t\tvar offsetValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.LOCAL_STATIC)? animationRegisterCache.getFreeVertexAttribute() : animationRegisterCache.getFreeVertexConstant();\n\t\t\t\tanimationRegisterCache.setRegisterIndex(this, ParticleInitialColorState.OFFSET_INDEX, offsetValue.index);\n\n\t\t\t\tcode += \"add \" + animationRegisterCache.colorAddTarget + \",\" + offsetValue + \",\" + animationRegisterCache.colorAddTarget + \"\\n\";\n\t\t\t}\n\t\t}\n\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _iProcessAnimationSetting(particleAnimationSet:ParticleAnimationSet)\n\t{\n\t\tif (this._iUsesMultiplier)\n\t\t\tparticleAnimationSet.hasColorMulNode = true;\n\t\tif (this._iUsesOffset)\n\t\t\tparticleAnimationSet.hasColorAddNode = true;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _iGeneratePropertyOfOneParticle(param:ParticleProperties)\n\t{\n\t\tvar initialColor:ColorTransform = param[ParticleInitialColorNode.COLOR_INITIAL_COLORTRANSFORM];\n\t\tif (!initialColor)\n\t\t\tthrow(new Error(\"there is no \" + ParticleInitialColorNode.COLOR_INITIAL_COLORTRANSFORM + \" in param!\"));\n\n\t\tvar i:number /*uint*/ = 0;\n\n\t\t//multiplier\n\t\tif (this._iUsesMultiplier) {\n\t\t\tthis._pOneData[i++] = initialColor.redMultiplier;\n\t\t\tthis._pOneData[i++] = initialColor.greenMultiplier;\n\t\t\tthis._pOneData[i++] = initialColor.blueMultiplier;\n\t\t\tthis._pOneData[i++] = initialColor.alphaMultiplier;\n\t\t}\n\t\t//offset\n\t\tif (this._iUsesOffset) {\n\t\t\tthis._pOneData[i++] = initialColor.redOffset/255;\n\t\t\tthis._pOneData[i++] = initialColor.greenOffset/255;\n\t\t\tthis._pOneData[i++] = initialColor.blueOffset/255;\n\t\t\tthis._pOneData[i++] = initialColor.alphaOffset/255;\n\t\t}\n\n\t}\n\n}\n\nexport = ParticleInitialColorNode;"]}
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleInitialColorNode.ts b/lib/animators/nodes/ParticleInitialColorNode.ts
new file mode 100644
index 000000000..2f480d5ef
--- /dev/null
+++ b/lib/animators/nodes/ParticleInitialColorNode.ts
@@ -0,0 +1,112 @@
+import ColorTransform = require("awayjs-core/lib/core/geom/ColorTransform");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+
+import ParticleAnimationSet = require("awayjs-renderergl/lib/animators/ParticleAnimationSet");
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleInitialColorState = require("awayjs-renderergl/lib/animators/states/ParticleInitialColorState");
+
+/**
+ *
+ */
+class ParticleInitialColorNode extends ParticleNodeBase
+{
+ //default values used when creating states
+ /** @private */
+ public _iUsesMultiplier:boolean;
+ /** @private */
+ public _iUsesOffset:boolean;
+ /** @private */
+ public _iInitialColor:ColorTransform;
+
+ /**
+ * Reference for color node properties on a single particle (when in local property mode).
+ * Expects a ColorTransform
object representing the color transform applied to the particle.
+ */
+ public static COLOR_INITIAL_COLORTRANSFORM:string = "ColorInitialColorTransform";
+
+ constructor(mode:number /*uint*/, usesMultiplier:boolean = true, usesOffset:boolean = false, initialColor:ColorTransform = null)
+ {
+ super("ParticleInitialColor", mode, (usesMultiplier && usesOffset)? 8 : 4, ParticleAnimationSet.COLOR_PRIORITY);
+
+ this._pStateClass = ParticleInitialColorState;
+
+ this._iUsesMultiplier = usesMultiplier;
+ this._iUsesOffset = usesOffset;
+ this._iInitialColor = initialColor || new ColorTransform();
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ var code:string = "";
+ if (animationRegisterCache.needFragmentAnimation) {
+
+ if (this._iUsesMultiplier) {
+ var multiplierValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleInitialColorState.MULTIPLIER_INDEX, multiplierValue.index);
+
+ code += "mul " + animationRegisterCache.colorMulTarget + "," + multiplierValue + "," + animationRegisterCache.colorMulTarget + "\n";
+ }
+
+ if (this._iUsesOffset) {
+ var offsetValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.LOCAL_STATIC)? animationRegisterCache.getFreeVertexAttribute() : animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleInitialColorState.OFFSET_INDEX, offsetValue.index);
+
+ code += "add " + animationRegisterCache.colorAddTarget + "," + offsetValue + "," + animationRegisterCache.colorAddTarget + "\n";
+ }
+ }
+
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iProcessAnimationSetting(particleAnimationSet:ParticleAnimationSet)
+ {
+ if (this._iUsesMultiplier)
+ particleAnimationSet.hasColorMulNode = true;
+ if (this._iUsesOffset)
+ particleAnimationSet.hasColorAddNode = true;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iGeneratePropertyOfOneParticle(param:ParticleProperties)
+ {
+ var initialColor:ColorTransform = param[ParticleInitialColorNode.COLOR_INITIAL_COLORTRANSFORM];
+ if (!initialColor)
+ throw(new Error("there is no " + ParticleInitialColorNode.COLOR_INITIAL_COLORTRANSFORM + " in param!"));
+
+ var i:number /*uint*/ = 0;
+
+ //multiplier
+ if (this._iUsesMultiplier) {
+ this._pOneData[i++] = initialColor.redMultiplier;
+ this._pOneData[i++] = initialColor.greenMultiplier;
+ this._pOneData[i++] = initialColor.blueMultiplier;
+ this._pOneData[i++] = initialColor.alphaMultiplier;
+ }
+ //offset
+ if (this._iUsesOffset) {
+ this._pOneData[i++] = initialColor.redOffset/255;
+ this._pOneData[i++] = initialColor.greenOffset/255;
+ this._pOneData[i++] = initialColor.blueOffset/255;
+ this._pOneData[i++] = initialColor.alphaOffset/255;
+ }
+
+ }
+
+}
+
+export = ParticleInitialColorNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleNodeBase.js b/lib/animators/nodes/ParticleNodeBase.js
new file mode 100755
index 000000000..da6d7d6ff
--- /dev/null
+++ b/lib/animators/nodes/ParticleNodeBase.js
@@ -0,0 +1,127 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var AnimationNodeBase = require("awayjs-core/lib/animators/nodes/AnimationNodeBase");
+/**
+ * Provides an abstract base class for particle animation nodes.
+ */
+var ParticleNodeBase = (function (_super) {
+ __extends(ParticleNodeBase, _super);
+ /**
+ * Creates a new ParticleNodeBase
object.
+ *
+ * @param name Defines the generic name of the particle animation node.
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param dataLength Defines the length of the data used by the node when in LOCAL_STATIC
mode.
+ * @param [optional] priority the priority of the particle animation node, used to order the agal generated in a particle animation set. Defaults to 1.
+ */
+ function ParticleNodeBase(name, mode /*uint*/, dataLength /*uint*/, priority) {
+ if (priority === void 0) { priority = 1; }
+ _super.call(this);
+ this._pDataLength = 3;
+ name = name + ParticleNodeBase.MODES[mode];
+ this.name = name;
+ this._pMode = mode;
+ this._priority = priority;
+ this._pDataLength = dataLength;
+ this._pOneData = new Array(this._pDataLength);
+ }
+ Object.defineProperty(ParticleNodeBase.prototype, "mode", {
+ /**
+ * Returns the property mode of the particle animation node. Typically set in the node constructor
+ *
+ * @see away.animators.ParticlePropertiesMode
+ */
+ get: function () {
+ return this._pMode;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleNodeBase.prototype, "priority", {
+ /**
+ * Returns the priority of the particle animation node, used to order the agal generated in a particle animation set. Set automatically on instantiation.
+ *
+ * @see away.animators.ParticleAnimationSet
+ * @see #getAGALVertexCode
+ */
+ get: function () {
+ return this._priority;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleNodeBase.prototype, "dataLength", {
+ /**
+ * Returns the length of the data used by the node when in LOCAL_STATIC
mode. Used to generate the local static data of the particle animation set.
+ *
+ * @see away.animators.ParticleAnimationSet
+ * @see #getAGALVertexCode
+ */
+ get: function () {
+ return this._pDataLength;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleNodeBase.prototype, "oneData", {
+ /**
+ * Returns the generated data vector of the node after one particle pass during the generation of all local static data of the particle animation set.
+ *
+ * @see away.animators.ParticleAnimationSet
+ * @see #generatePropertyOfOneParticle
+ */
+ get: function () {
+ return this._pOneData;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * Returns the AGAL code of the particle animation node for use in the vertex shader.
+ */
+ ParticleNodeBase.prototype.getAGALVertexCode = function (shaderObject, animationRegisterCache) {
+ return "";
+ };
+ /**
+ * Returns the AGAL code of the particle animation node for use in the fragment shader.
+ */
+ ParticleNodeBase.prototype.getAGALFragmentCode = function (shaderObject, animationRegisterCache) {
+ return "";
+ };
+ /**
+ * Returns the AGAL code of the particle animation node for use in the fragment shader when UV coordinates are required.
+ */
+ ParticleNodeBase.prototype.getAGALUVCode = function (shaderObject, animationRegisterCache) {
+ return "";
+ };
+ /**
+ * Called internally by the particle animation set when assigning the set of static properties originally defined by the initParticleFunc of the set.
+ *
+ * @see away.animators.ParticleAnimationSet#initParticleFunc
+ */
+ ParticleNodeBase.prototype._iGeneratePropertyOfOneParticle = function (param) {
+ };
+ /**
+ * Called internally by the particle animation set when determining the requirements of the particle animation node AGAL.
+ */
+ ParticleNodeBase.prototype._iProcessAnimationSetting = function (particleAnimationSet) {
+ };
+ //modes alias
+ ParticleNodeBase.GLOBAL = 'Global';
+ ParticleNodeBase.LOCAL_STATIC = 'LocalStatic';
+ ParticleNodeBase.LOCAL_DYNAMIC = 'LocalDynamic';
+ //modes list
+ ParticleNodeBase.MODES = {
+ 0: ParticleNodeBase.GLOBAL,
+ 1: ParticleNodeBase.LOCAL_STATIC,
+ 2: ParticleNodeBase.LOCAL_DYNAMIC
+ };
+ return ParticleNodeBase;
+})(AnimationNodeBase);
+module.exports = ParticleNodeBase;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/nodes/particlenodebase.ts"],"names":["ParticleNodeBase","ParticleNodeBase.constructor","ParticleNodeBase.mode","ParticleNodeBase.priority","ParticleNodeBase.dataLength","ParticleNodeBase.oneData","ParticleNodeBase.getAGALVertexCode","ParticleNodeBase.getAGALFragmentCode","ParticleNodeBase.getAGALUVCode","ParticleNodeBase._iGeneratePropertyOfOneParticle","ParticleNodeBase._iProcessAnimationSetting"],"mappings":";;;;;;AAAA,IAAO,iBAAiB,WAAc,mDAAmD,CAAC,CAAC;AAQ3F,AAGA;;GADG;IACG,gBAAgB;IAASA,UAAzBA,gBAAgBA,UAA0BA;IAkE/CA;;;;;;;OAOGA;IACHA,SA1EKA,gBAAgBA,CA0ETA,IAAWA,EAAEA,IAAIA,CAAQA,QAADA,AAASA,EAAEA,UAAUA,CAAQA,QAADA,AAASA,EAAEA,QAA2BA;QAA3BC,wBAA2BA,GAA3BA,YAA2BA;QAErGA,iBAAOA,CAACA;QAvEFA,iBAAYA,GAAmBA,CAACA,CAACA;QAyEvCA,IAAIA,GAAGA,IAAIA,GAAGA,gBAAgBA,CAACA,KAAKA,CAACA,IAAIA,CAACA,CAACA;QAE3CA,IAAIA,CAACA,IAAIA,GAAGA,IAAIA,CAACA;QACjBA,IAAIA,CAACA,MAAMA,GAAGA,IAAIA,CAACA;QACnBA,IAAIA,CAACA,SAASA,GAAGA,QAAQA,CAACA;QAC1BA,IAAIA,CAACA,YAAYA,GAAGA,UAAUA,CAACA;QAE/BA,IAAIA,CAACA,SAASA,GAAGA,IAAIA,KAAKA,CAASA,IAAIA,CAACA,YAAYA,CAACA,CAACA;IACvDA,CAACA;IA1DDD,sBAAWA,kCAAIA;QALfA;;;;WAIGA;aACHA;YAECE,MAAMA,CAACA,IAAIA,CAACA,MAAMA,CAACA;QACpBA,CAACA;;;OAAAF;IAQDA,sBAAWA,sCAAQA;QANnBA;;;;;WAKGA;aACHA;YAECG,MAAMA,CAACA,IAAIA,CAACA,SAASA,CAACA;QACvBA,CAACA;;;OAAAH;IAQDA,sBAAWA,wCAAUA;QANrBA;;;;;WAKGA;aACHA;YAECI,MAAMA,CAACA,IAAIA,CAACA,YAAYA,CAACA;QAC1BA,CAACA;;;OAAAJ;IAQDA,sBAAWA,qCAAOA;QANlBA;;;;;WAKGA;aACHA;YAECK,MAAMA,CAACA,IAAIA,CAACA,SAASA,CAACA;QACvBA,CAACA;;;OAAAL;IAwBDA;;OAEGA;IACIA,4CAAiBA,GAAxBA,UAAyBA,YAA6BA,EAAEA,sBAA6CA;QAEpGM,MAAMA,CAACA,EAAEA,CAACA;IACXA,CAACA;IAEDN;;OAEGA;IACIA,8CAAmBA,GAA1BA,UAA2BA,YAA6BA,EAAEA,sBAA6CA;QAEtGO,MAAMA,CAACA,EAAEA,CAACA;IACXA,CAACA;IAEDP;;OAEGA;IACIA,wCAAaA,GAApBA,UAAqBA,YAA6BA,EAAEA,sBAA6CA;QAEhGQ,MAAMA,CAACA,EAAEA,CAACA;IACXA,CAACA;IAEDR;;;;OAIGA;IACIA,0DAA+BA,GAAtCA,UAAuCA,KAAwBA;IAG/DS,CAACA;IAEDT;;OAEGA;IACIA,oDAAyBA,GAAhCA,UAAiCA,oBAAyCA;IAG1EU,CAACA;IAtHDV,aAAaA;IACEA,uBAAMA,GAAUA,QAAQA,CAACA;IACzBA,6BAAYA,GAAUA,aAAaA,CAACA;IACpCA,8BAAaA,GAAUA,cAAcA,CAACA;IAErDA,YAAYA;IACGA,sBAAKA,GACpBA;QACCA,CAACA,EAACA,gBAAgBA,CAACA,MAAMA;QACzBA,CAACA,EAACA,gBAAgBA,CAACA,YAAYA;QAC/BA,CAACA,EAACA,gBAAgBA,CAACA,aAAaA;KAChCA,CAACA;IA4GHA,uBAACA;AAADA,CAjIA,AAiICA,EAjI8B,iBAAiB,EAiI/C;AAED,AAA0B,iBAAjB,gBAAgB,CAAC","file":"animators/nodes/ParticleNodeBase.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import AnimationNodeBase\t\t\t\t= require(\"awayjs-core/lib/animators/nodes/AnimationNodeBase\");\n\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\n\nimport ParticleAnimationSet\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimationSet\");\nimport ParticleProperties\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleProperties\");\n\n/**\n * Provides an abstract base class for particle animation nodes.\n */\nclass ParticleNodeBase extends AnimationNodeBase\n{\n\tprivate _priority:number /*int*/;\n\n\tpublic _pMode:number /*uint*/;\n\tpublic _pDataLength:number /*uint*/ = 3;\n\tpublic _pOneData:Array<number>;\n\n\tpublic _iDataOffset:number /*uint*/;\n\n\t//modes alias\n\tprivate static GLOBAL:string = 'Global';\n\tprivate static LOCAL_STATIC:string = 'LocalStatic';\n\tprivate static LOCAL_DYNAMIC:string = 'LocalDynamic';\n\n\t//modes list\n\tprivate static MODES:Object =\n\t{\n\t\t0:ParticleNodeBase.GLOBAL,\n\t\t1:ParticleNodeBase.LOCAL_STATIC,\n\t\t2:ParticleNodeBase.LOCAL_DYNAMIC\n\t};\n\n\t/**\n\t * Returns the property mode of the particle animation node. Typically set in the node constructor\n\t *\n\t * @see away.animators.ParticlePropertiesMode\n\t */\n\tpublic get mode():number /*uint*/\n\t{\n\t\treturn this._pMode;\n\t}\n\n\t/**\n\t * Returns the priority of the particle animation node, used to order the agal generated in a particle animation set. Set automatically on instantiation.\n\t *\n\t * @see away.animators.ParticleAnimationSet\n\t * @see #getAGALVertexCode\n\t */\n\tpublic get priority():number /*int*/\n\t{\n\t\treturn this._priority;\n\t}\n\n\t/**\n\t * Returns the length of the data used by the node when in <code>LOCAL_STATIC</code> mode. Used to generate the local static data of the particle animation set.\n\t *\n\t * @see away.animators.ParticleAnimationSet\n\t * @see #getAGALVertexCode\n\t */\n\tpublic get dataLength():number /*int*/\n\t{\n\t\treturn this._pDataLength;\n\t}\n\n\t/**\n\t * Returns the generated data vector of the node after one particle pass during the generation of all local static data of the particle animation set.\n\t *\n\t * @see away.animators.ParticleAnimationSet\n\t * @see #generatePropertyOfOneParticle\n\t */\n\tpublic get oneData():Array<number>\n\t{\n\t\treturn this._pOneData;\n\t}\n\n\t/**\n\t * Creates a new <code>ParticleNodeBase</code> object.\n\t *\n\t * @param               name            Defines the generic name of the particle animation node.\n\t * @param               mode            Defines whether the mode of operation acts on local properties of a particle or global properties of the node.\n\t * @param               dataLength      Defines the length of the data used by the node when in <code>LOCAL_STATIC</code> mode.\n\t * @param    [optional] priority        the priority of the particle animation node, used to order the agal generated in a particle animation set. Defaults to 1.\n\t */\n\tconstructor(name:string, mode:number /*uint*/, dataLength:number /*uint*/, priority:number /*int*/ = 1)\n\t{\n\t\tsuper();\n\n\t\tname = name + ParticleNodeBase.MODES[mode];\n\n\t\tthis.name = name;\n\t\tthis._pMode = mode;\n\t\tthis._priority = priority;\n\t\tthis._pDataLength = dataLength;\n\n\t\tthis._pOneData = new Array<number>(this._pDataLength);\n\t}\n\n\t/**\n\t * Returns the AGAL code of the particle animation node for use in the vertex shader.\n\t */\n\tpublic getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string\n\t{\n\t\treturn \"\";\n\t}\n\n\t/**\n\t * Returns the AGAL code of the particle animation node for use in the fragment shader.\n\t */\n\tpublic getAGALFragmentCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string\n\t{\n\t\treturn \"\";\n\t}\n\n\t/**\n\t * Returns the AGAL code of the particle animation node for use in the fragment shader when UV coordinates are required.\n\t */\n\tpublic getAGALUVCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string\n\t{\n\t\treturn \"\";\n\t}\n\n\t/**\n\t * Called internally by the particle animation set when assigning the set of static properties originally defined by the initParticleFunc of the set.\n\t *\n\t * @see away.animators.ParticleAnimationSet#initParticleFunc\n\t */\n\tpublic _iGeneratePropertyOfOneParticle(param:ParticleProperties)\n\t{\n\n\t}\n\n\t/**\n\t * Called internally by the particle animation set when determining the requirements of the particle animation node AGAL.\n\t */\n\tpublic _iProcessAnimationSetting(particleAnimationSet:ParticleAnimationSet)\n\t{\n\n\t}\n}\n\nexport = ParticleNodeBase;"]}
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleNodeBase.ts b/lib/animators/nodes/ParticleNodeBase.ts
new file mode 100644
index 000000000..4bdf0a66c
--- /dev/null
+++ b/lib/animators/nodes/ParticleNodeBase.ts
@@ -0,0 +1,143 @@
+import AnimationNodeBase = require("awayjs-core/lib/animators/nodes/AnimationNodeBase");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+
+import ParticleAnimationSet = require("awayjs-renderergl/lib/animators/ParticleAnimationSet");
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+
+/**
+ * Provides an abstract base class for particle animation nodes.
+ */
+class ParticleNodeBase extends AnimationNodeBase
+{
+ private _priority:number /*int*/;
+
+ public _pMode:number /*uint*/;
+ public _pDataLength:number /*uint*/ = 3;
+ public _pOneData:Array;
+
+ public _iDataOffset:number /*uint*/;
+
+ //modes alias
+ private static GLOBAL:string = 'Global';
+ private static LOCAL_STATIC:string = 'LocalStatic';
+ private static LOCAL_DYNAMIC:string = 'LocalDynamic';
+
+ //modes list
+ private static MODES:Object =
+ {
+ 0:ParticleNodeBase.GLOBAL,
+ 1:ParticleNodeBase.LOCAL_STATIC,
+ 2:ParticleNodeBase.LOCAL_DYNAMIC
+ };
+
+ /**
+ * Returns the property mode of the particle animation node. Typically set in the node constructor
+ *
+ * @see away.animators.ParticlePropertiesMode
+ */
+ public get mode():number /*uint*/
+ {
+ return this._pMode;
+ }
+
+ /**
+ * Returns the priority of the particle animation node, used to order the agal generated in a particle animation set. Set automatically on instantiation.
+ *
+ * @see away.animators.ParticleAnimationSet
+ * @see #getAGALVertexCode
+ */
+ public get priority():number /*int*/
+ {
+ return this._priority;
+ }
+
+ /**
+ * Returns the length of the data used by the node when in LOCAL_STATIC
mode. Used to generate the local static data of the particle animation set.
+ *
+ * @see away.animators.ParticleAnimationSet
+ * @see #getAGALVertexCode
+ */
+ public get dataLength():number /*int*/
+ {
+ return this._pDataLength;
+ }
+
+ /**
+ * Returns the generated data vector of the node after one particle pass during the generation of all local static data of the particle animation set.
+ *
+ * @see away.animators.ParticleAnimationSet
+ * @see #generatePropertyOfOneParticle
+ */
+ public get oneData():Array
+ {
+ return this._pOneData;
+ }
+
+ /**
+ * Creates a new ParticleNodeBase
object.
+ *
+ * @param name Defines the generic name of the particle animation node.
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param dataLength Defines the length of the data used by the node when in LOCAL_STATIC
mode.
+ * @param [optional] priority the priority of the particle animation node, used to order the agal generated in a particle animation set. Defaults to 1.
+ */
+ constructor(name:string, mode:number /*uint*/, dataLength:number /*uint*/, priority:number /*int*/ = 1)
+ {
+ super();
+
+ name = name + ParticleNodeBase.MODES[mode];
+
+ this.name = name;
+ this._pMode = mode;
+ this._priority = priority;
+ this._pDataLength = dataLength;
+
+ this._pOneData = new Array(this._pDataLength);
+ }
+
+ /**
+ * Returns the AGAL code of the particle animation node for use in the vertex shader.
+ */
+ public getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ return "";
+ }
+
+ /**
+ * Returns the AGAL code of the particle animation node for use in the fragment shader.
+ */
+ public getAGALFragmentCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ return "";
+ }
+
+ /**
+ * Returns the AGAL code of the particle animation node for use in the fragment shader when UV coordinates are required.
+ */
+ public getAGALUVCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ return "";
+ }
+
+ /**
+ * Called internally by the particle animation set when assigning the set of static properties originally defined by the initParticleFunc of the set.
+ *
+ * @see away.animators.ParticleAnimationSet#initParticleFunc
+ */
+ public _iGeneratePropertyOfOneParticle(param:ParticleProperties)
+ {
+
+ }
+
+ /**
+ * Called internally by the particle animation set when determining the requirements of the particle animation node AGAL.
+ */
+ public _iProcessAnimationSetting(particleAnimationSet:ParticleAnimationSet)
+ {
+
+ }
+}
+
+export = ParticleNodeBase;
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleOrbitNode.js b/lib/animators/nodes/ParticleOrbitNode.js
new file mode 100755
index 000000000..09530b120
--- /dev/null
+++ b/lib/animators/nodes/ParticleOrbitNode.js
@@ -0,0 +1,130 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+var ParticleOrbitState = require("awayjs-renderergl/lib/animators/states/ParticleOrbitState");
+/**
+ * A particle animation node used to control the position of a particle over time around a circular orbit.
+ */
+var ParticleOrbitNode = (function (_super) {
+ __extends(ParticleOrbitNode, _super);
+ /**
+ * Creates a new ParticleOrbitNode
object.
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] usesEulers Defines whether the node uses the eulers
property in the shader to calculate a rotation on the orbit. Defaults to true.
+ * @param [optional] usesCycle Defines whether the node uses the cycleDuration
property in the shader to calculate the period of the orbit independent of particle duration. Defaults to false.
+ * @param [optional] usesPhase Defines whether the node uses the cyclePhase
property in the shader to calculate a starting offset to the cycle rotation of the particle. Defaults to false.
+ * @param [optional] radius Defines the radius of the orbit when in global mode. Defaults to 100.
+ * @param [optional] cycleDuration Defines the duration of the orbit in seconds, used as a period independent of particle duration when in global mode. Defaults to 1.
+ * @param [optional] cyclePhase Defines the phase of the orbit in degrees, used as the starting offset of the cycle when in global mode. Defaults to 0.
+ * @param [optional] eulers Defines the euler rotation in degrees, applied to the orientation of the orbit when in global mode.
+ */
+ function ParticleOrbitNode(mode /*uint*/, usesEulers, usesCycle, usesPhase, radius, cycleDuration, cyclePhase, eulers) {
+ if (usesEulers === void 0) { usesEulers = true; }
+ if (usesCycle === void 0) { usesCycle = false; }
+ if (usesPhase === void 0) { usesPhase = false; }
+ if (radius === void 0) { radius = 100; }
+ if (cycleDuration === void 0) { cycleDuration = 1; }
+ if (cyclePhase === void 0) { cyclePhase = 0; }
+ if (eulers === void 0) { eulers = null; }
+ var len = 3;
+ if (usesPhase)
+ len++;
+ _super.call(this, "ParticleOrbit", mode, len);
+ this._pStateClass = ParticleOrbitState;
+ this._iUsesEulers = usesEulers;
+ this._iUsesCycle = usesCycle;
+ this._iUsesPhase = usesPhase;
+ this._iRadius = radius;
+ this._iCycleDuration = cycleDuration;
+ this._iCyclePhase = cyclePhase;
+ this._iEulers = eulers || new Vector3D();
+ }
+ /**
+ * @inheritDoc
+ */
+ ParticleOrbitNode.prototype.getAGALVertexCode = function (shaderObject, animationRegisterCache) {
+ var orbitRegister = (this._pMode == ParticlePropertiesMode.GLOBAL) ? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleOrbitState.ORBIT_INDEX, orbitRegister.index);
+ var eulersMatrixRegister = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleOrbitState.EULERS_INDEX, eulersMatrixRegister.index);
+ animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.getFreeVertexConstant();
+ var temp1 = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp1, 1);
+ var distance = new ShaderRegisterElement(temp1.regName, temp1.index);
+ var temp2 = animationRegisterCache.getFreeVertexVectorTemp();
+ var cos = new ShaderRegisterElement(temp2.regName, temp2.index, 0);
+ var sin = new ShaderRegisterElement(temp2.regName, temp2.index, 1);
+ var degree = new ShaderRegisterElement(temp2.regName, temp2.index, 2);
+ animationRegisterCache.removeVertexTempUsage(temp1);
+ var code = "";
+ if (this._iUsesCycle) {
+ code += "mul " + degree + "," + animationRegisterCache.vertexTime + "," + orbitRegister + ".y\n";
+ if (this._iUsesPhase)
+ code += "add " + degree + "," + degree + "," + orbitRegister + ".w\n";
+ }
+ else
+ code += "mul " + degree + "," + animationRegisterCache.vertexLife + "," + orbitRegister + ".y\n";
+ code += "cos " + cos + "," + degree + "\n";
+ code += "sin " + sin + "," + degree + "\n";
+ code += "mul " + distance + ".x," + cos + "," + orbitRegister + ".x\n";
+ code += "mul " + distance + ".y," + sin + "," + orbitRegister + ".x\n";
+ code += "mov " + distance + ".wz" + animationRegisterCache.vertexZeroConst + "\n";
+ if (this._iUsesEulers)
+ code += "m44 " + distance + "," + distance + "," + eulersMatrixRegister + "\n";
+ code += "add " + animationRegisterCache.positionTarget + ".xyz," + distance + ".xyz," + animationRegisterCache.positionTarget + ".xyz\n";
+ if (animationRegisterCache.needVelocity) {
+ code += "neg " + distance + ".x," + sin + "\n";
+ code += "mov " + distance + ".y," + cos + "\n";
+ code += "mov " + distance + ".zw," + animationRegisterCache.vertexZeroConst + "\n";
+ if (this._iUsesEulers)
+ code += "m44 " + distance + "," + distance + "," + eulersMatrixRegister + "\n";
+ code += "mul " + distance + "," + distance + "," + orbitRegister + ".z\n";
+ code += "div " + distance + "," + distance + "," + orbitRegister + ".y\n";
+ if (!this._iUsesCycle)
+ code += "div " + distance + "," + distance + "," + animationRegisterCache.vertexLife + "\n";
+ code += "add " + animationRegisterCache.velocityTarget + ".xyz," + animationRegisterCache.velocityTarget + ".xyz," + distance + ".xyz\n";
+ }
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleOrbitNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleOrbitNode.prototype._iGeneratePropertyOfOneParticle = function (param) {
+ //Vector3D.x is radius, Vector3D.y is cycle duration, Vector3D.z is phase
+ var orbit = param[ParticleOrbitNode.ORBIT_VECTOR3D];
+ if (!orbit)
+ throw new Error("there is no " + ParticleOrbitNode.ORBIT_VECTOR3D + " in param!");
+ this._pOneData[0] = orbit.x;
+ if (this._iUsesCycle && orbit.y <= 0)
+ throw (new Error("the cycle duration must be greater than zero"));
+ this._pOneData[1] = Math.PI * 2 / (!this._iUsesCycle ? 1 : orbit.y);
+ this._pOneData[2] = orbit.x * Math.PI * 2;
+ if (this._iUsesPhase)
+ this._pOneData[3] = orbit.z * Math.PI / 180;
+ };
+ /**
+ * Reference for orbit node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
object representing the radius (x), cycle speed (y) and cycle phase (z) of the motion on the particle.
+ */
+ ParticleOrbitNode.ORBIT_VECTOR3D = "OrbitVector3D";
+ return ParticleOrbitNode;
+})(ParticleNodeBase);
+module.exports = ParticleOrbitNode;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/nodes/particleorbitnode.ts"],"names":["ParticleOrbitNode","ParticleOrbitNode.constructor","ParticleOrbitNode.getAGALVertexCode","ParticleOrbitNode.getAnimationState","ParticleOrbitNode._iGeneratePropertyOfOneParticle"],"mappings":"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","file":"animators/nodes/ParticleOrbitNode.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\n\nimport ParticleProperties\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleProperties\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleNodeBase\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleNodeBase\");\nimport ParticleOrbitState\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleOrbitState\");\n\n/**\n * A particle animation node used to control the position of a particle over time around a circular orbit.\n */\nclass ParticleOrbitNode extends ParticleNodeBase\n{\n\t/** @private */\n\tpublic _iUsesEulers:boolean;\n\n\t/** @private */\n\tpublic _iUsesCycle:boolean;\n\n\t/** @private */\n\tpublic _iUsesPhase:boolean;\n\n\t/** @private */\n\tpublic _iRadius:number;\n\t/** @private */\n\tpublic _iCycleDuration:number;\n\t/** @private */\n\tpublic _iCyclePhase:number;\n\t/** @private */\n\tpublic _iEulers:Vector3D;\n\n\t/**\n\t * Reference for orbit node properties on a single particle (when in local property mode).\n\t * Expects a <code>Vector3D</code> object representing the radius (x), cycle speed (y) and cycle phase (z) of the motion on the particle.\n\t */\n\tpublic static ORBIT_VECTOR3D:string = \"OrbitVector3D\";\n\n\t/**\n\t * Creates a new <code>ParticleOrbitNode</code> object.\n\t *\n\t * @param               mode            Defines whether the mode of operation acts on local properties of a particle or global properties of the node.\n\t * @param    [optional] usesEulers      Defines whether the node uses the <code>eulers</code> property in the shader to calculate a rotation on the orbit. Defaults to true.\n\t * @param    [optional] usesCycle       Defines whether the node uses the <code>cycleDuration</code> property in the shader to calculate the period of the orbit independent of particle duration. Defaults to false.\n\t * @param    [optional] usesPhase       Defines whether the node uses the <code>cyclePhase</code> property in the shader to calculate a starting offset to the cycle rotation of the particle. Defaults to false.\n\t * @param    [optional] radius          Defines the radius of the orbit when in global mode. Defaults to 100.\n\t * @param    [optional] cycleDuration   Defines the duration of the orbit in seconds, used as a period independent of particle duration when in global mode. Defaults to 1.\n\t * @param    [optional] cyclePhase      Defines the phase of the orbit in degrees, used as the starting offset of the cycle when in global mode. Defaults to 0.\n\t * @param    [optional] eulers          Defines the euler rotation in degrees, applied to the orientation of the orbit when in global mode.\n\t */\n\tconstructor(mode:number /*uint*/, usesEulers:boolean = true, usesCycle:boolean = false, usesPhase:boolean = false, radius:number = 100, cycleDuration:number = 1, cyclePhase:number = 0, eulers:Vector3D = null)\n\t{\n\t\tvar len:number /*int*/ = 3;\n\t\tif (usesPhase)\n\t\t\tlen++;\n\t\tsuper(\"ParticleOrbit\", mode, len);\n\n\t\tthis._pStateClass = ParticleOrbitState;\n\n\t\tthis._iUsesEulers = usesEulers;\n\t\tthis._iUsesCycle = usesCycle;\n\t\tthis._iUsesPhase = usesPhase;\n\n\t\tthis._iRadius = radius;\n\t\tthis._iCycleDuration = cycleDuration;\n\t\tthis._iCyclePhase = cyclePhase;\n\t\tthis._iEulers = eulers || new Vector3D();\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string\n\t{\n\t\tvar orbitRegister:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();\n\t\tanimationRegisterCache.setRegisterIndex(this, ParticleOrbitState.ORBIT_INDEX, orbitRegister.index);\n\n\t\tvar eulersMatrixRegister:ShaderRegisterElement = animationRegisterCache.getFreeVertexConstant();\n\t\tanimationRegisterCache.setRegisterIndex(this, ParticleOrbitState.EULERS_INDEX, eulersMatrixRegister.index);\n\t\tanimationRegisterCache.getFreeVertexConstant();\n\t\tanimationRegisterCache.getFreeVertexConstant();\n\t\tanimationRegisterCache.getFreeVertexConstant();\n\n\t\tvar temp1:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\tanimationRegisterCache.addVertexTempUsages(temp1, 1);\n\t\tvar distance:ShaderRegisterElement = new ShaderRegisterElement(temp1.regName, temp1.index);\n\n\t\tvar temp2:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\tvar cos:ShaderRegisterElement = new ShaderRegisterElement(temp2.regName, temp2.index, 0);\n\t\tvar sin:ShaderRegisterElement = new ShaderRegisterElement(temp2.regName, temp2.index, 1);\n\t\tvar degree:ShaderRegisterElement = new ShaderRegisterElement(temp2.regName, temp2.index, 2);\n\t\tanimationRegisterCache.removeVertexTempUsage(temp1);\n\n\t\tvar code:string = \"\";\n\n\t\tif (this._iUsesCycle) {\n\t\t\tcode += \"mul \" + degree + \",\" + animationRegisterCache.vertexTime + \",\" + orbitRegister + \".y\\n\";\n\n\t\t\tif (this._iUsesPhase)\n\t\t\t\tcode += \"add \" + degree + \",\" + degree + \",\" + orbitRegister + \".w\\n\";\n\t\t} else\n\t\t\tcode += \"mul \" + degree + \",\" + animationRegisterCache.vertexLife + \",\" + orbitRegister + \".y\\n\";\n\n\t\tcode += \"cos \" + cos + \",\" + degree + \"\\n\";\n\t\tcode += \"sin \" + sin + \",\" + degree + \"\\n\";\n\t\tcode += \"mul \" + distance + \".x,\" + cos + \",\" + orbitRegister + \".x\\n\";\n\t\tcode += \"mul \" + distance + \".y,\" + sin + \",\" + orbitRegister + \".x\\n\";\n\t\tcode += \"mov \" + distance + \".wz\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\tif (this._iUsesEulers)\n\t\t\tcode += \"m44 \" + distance + \",\" + distance + \",\" + eulersMatrixRegister + \"\\n\";\n\t\tcode += \"add \" + animationRegisterCache.positionTarget + \".xyz,\" + distance + \".xyz,\" + animationRegisterCache.positionTarget + \".xyz\\n\";\n\n\t\tif (animationRegisterCache.needVelocity) {\n\t\t\tcode += \"neg \" + distance + \".x,\" + sin + \"\\n\";\n\t\t\tcode += \"mov \" + distance + \".y,\" + cos + \"\\n\";\n\t\t\tcode += \"mov \" + distance + \".zw,\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tif (this._iUsesEulers)\n\t\t\t\tcode += \"m44 \" + distance + \",\" + distance + \",\" + eulersMatrixRegister + \"\\n\";\n\t\t\tcode += \"mul \" + distance + \",\" + distance + \",\" + orbitRegister + \".z\\n\";\n\t\t\tcode += \"div \" + distance + \",\" + distance + \",\" + orbitRegister + \".y\\n\";\n\t\t\tif (!this._iUsesCycle)\n\t\t\t\tcode += \"div \" + distance + \",\" + distance + \",\" + animationRegisterCache.vertexLife + \"\\n\";\n\t\t\tcode += \"add \" + animationRegisterCache.velocityTarget + \".xyz,\" + animationRegisterCache.velocityTarget + \".xyz,\" + distance + \".xyz\\n\";\n\t\t}\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAnimationState(animator:AnimatorBase):ParticleOrbitState\n\t{\n\t\treturn <ParticleOrbitState> animator.getAnimationState(this);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _iGeneratePropertyOfOneParticle(param:ParticleProperties)\n\t{\n\t\t//Vector3D.x is radius, Vector3D.y is cycle duration, Vector3D.z is phase\n\t\tvar orbit:Vector3D = param[ParticleOrbitNode.ORBIT_VECTOR3D];\n\t\tif (!orbit)\n\t\t\tthrow new Error(\"there is no \" + ParticleOrbitNode.ORBIT_VECTOR3D + \" in param!\");\n\n\t\tthis._pOneData[0] = orbit.x;\n\t\tif (this._iUsesCycle && orbit.y <= 0)\n\t\t\tthrow(new Error(\"the cycle duration must be greater than zero\"));\n\t\tthis._pOneData[1] = Math.PI*2/(!this._iUsesCycle? 1 : orbit.y);\n\t\tthis._pOneData[2] = orbit.x*Math.PI*2;\n\t\tif (this._iUsesPhase)\n\t\t\tthis._pOneData[3] = orbit.z*Math.PI/180;\n\t}\n}\n\nexport = ParticleOrbitNode;"]}
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleOrbitNode.ts b/lib/animators/nodes/ParticleOrbitNode.ts
new file mode 100644
index 000000000..f56e8c6cc
--- /dev/null
+++ b/lib/animators/nodes/ParticleOrbitNode.ts
@@ -0,0 +1,159 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleOrbitState = require("awayjs-renderergl/lib/animators/states/ParticleOrbitState");
+
+/**
+ * A particle animation node used to control the position of a particle over time around a circular orbit.
+ */
+class ParticleOrbitNode extends ParticleNodeBase
+{
+ /** @private */
+ public _iUsesEulers:boolean;
+
+ /** @private */
+ public _iUsesCycle:boolean;
+
+ /** @private */
+ public _iUsesPhase:boolean;
+
+ /** @private */
+ public _iRadius:number;
+ /** @private */
+ public _iCycleDuration:number;
+ /** @private */
+ public _iCyclePhase:number;
+ /** @private */
+ public _iEulers:Vector3D;
+
+ /**
+ * Reference for orbit node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
object representing the radius (x), cycle speed (y) and cycle phase (z) of the motion on the particle.
+ */
+ public static ORBIT_VECTOR3D:string = "OrbitVector3D";
+
+ /**
+ * Creates a new ParticleOrbitNode
object.
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] usesEulers Defines whether the node uses the eulers
property in the shader to calculate a rotation on the orbit. Defaults to true.
+ * @param [optional] usesCycle Defines whether the node uses the cycleDuration
property in the shader to calculate the period of the orbit independent of particle duration. Defaults to false.
+ * @param [optional] usesPhase Defines whether the node uses the cyclePhase
property in the shader to calculate a starting offset to the cycle rotation of the particle. Defaults to false.
+ * @param [optional] radius Defines the radius of the orbit when in global mode. Defaults to 100.
+ * @param [optional] cycleDuration Defines the duration of the orbit in seconds, used as a period independent of particle duration when in global mode. Defaults to 1.
+ * @param [optional] cyclePhase Defines the phase of the orbit in degrees, used as the starting offset of the cycle when in global mode. Defaults to 0.
+ * @param [optional] eulers Defines the euler rotation in degrees, applied to the orientation of the orbit when in global mode.
+ */
+ constructor(mode:number /*uint*/, usesEulers:boolean = true, usesCycle:boolean = false, usesPhase:boolean = false, radius:number = 100, cycleDuration:number = 1, cyclePhase:number = 0, eulers:Vector3D = null)
+ {
+ var len:number /*int*/ = 3;
+ if (usesPhase)
+ len++;
+ super("ParticleOrbit", mode, len);
+
+ this._pStateClass = ParticleOrbitState;
+
+ this._iUsesEulers = usesEulers;
+ this._iUsesCycle = usesCycle;
+ this._iUsesPhase = usesPhase;
+
+ this._iRadius = radius;
+ this._iCycleDuration = cycleDuration;
+ this._iCyclePhase = cyclePhase;
+ this._iEulers = eulers || new Vector3D();
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ var orbitRegister:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleOrbitState.ORBIT_INDEX, orbitRegister.index);
+
+ var eulersMatrixRegister:ShaderRegisterElement = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleOrbitState.EULERS_INDEX, eulersMatrixRegister.index);
+ animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.getFreeVertexConstant();
+
+ var temp1:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp1, 1);
+ var distance:ShaderRegisterElement = new ShaderRegisterElement(temp1.regName, temp1.index);
+
+ var temp2:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ var cos:ShaderRegisterElement = new ShaderRegisterElement(temp2.regName, temp2.index, 0);
+ var sin:ShaderRegisterElement = new ShaderRegisterElement(temp2.regName, temp2.index, 1);
+ var degree:ShaderRegisterElement = new ShaderRegisterElement(temp2.regName, temp2.index, 2);
+ animationRegisterCache.removeVertexTempUsage(temp1);
+
+ var code:string = "";
+
+ if (this._iUsesCycle) {
+ code += "mul " + degree + "," + animationRegisterCache.vertexTime + "," + orbitRegister + ".y\n";
+
+ if (this._iUsesPhase)
+ code += "add " + degree + "," + degree + "," + orbitRegister + ".w\n";
+ } else
+ code += "mul " + degree + "," + animationRegisterCache.vertexLife + "," + orbitRegister + ".y\n";
+
+ code += "cos " + cos + "," + degree + "\n";
+ code += "sin " + sin + "," + degree + "\n";
+ code += "mul " + distance + ".x," + cos + "," + orbitRegister + ".x\n";
+ code += "mul " + distance + ".y," + sin + "," + orbitRegister + ".x\n";
+ code += "mov " + distance + ".wz" + animationRegisterCache.vertexZeroConst + "\n";
+ if (this._iUsesEulers)
+ code += "m44 " + distance + "," + distance + "," + eulersMatrixRegister + "\n";
+ code += "add " + animationRegisterCache.positionTarget + ".xyz," + distance + ".xyz," + animationRegisterCache.positionTarget + ".xyz\n";
+
+ if (animationRegisterCache.needVelocity) {
+ code += "neg " + distance + ".x," + sin + "\n";
+ code += "mov " + distance + ".y," + cos + "\n";
+ code += "mov " + distance + ".zw," + animationRegisterCache.vertexZeroConst + "\n";
+ if (this._iUsesEulers)
+ code += "m44 " + distance + "," + distance + "," + eulersMatrixRegister + "\n";
+ code += "mul " + distance + "," + distance + "," + orbitRegister + ".z\n";
+ code += "div " + distance + "," + distance + "," + orbitRegister + ".y\n";
+ if (!this._iUsesCycle)
+ code += "div " + distance + "," + distance + "," + animationRegisterCache.vertexLife + "\n";
+ code += "add " + animationRegisterCache.velocityTarget + ".xyz," + animationRegisterCache.velocityTarget + ".xyz," + distance + ".xyz\n";
+ }
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):ParticleOrbitState
+ {
+ return animator.getAnimationState(this);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iGeneratePropertyOfOneParticle(param:ParticleProperties)
+ {
+ //Vector3D.x is radius, Vector3D.y is cycle duration, Vector3D.z is phase
+ var orbit:Vector3D = param[ParticleOrbitNode.ORBIT_VECTOR3D];
+ if (!orbit)
+ throw new Error("there is no " + ParticleOrbitNode.ORBIT_VECTOR3D + " in param!");
+
+ this._pOneData[0] = orbit.x;
+ if (this._iUsesCycle && orbit.y <= 0)
+ throw(new Error("the cycle duration must be greater than zero"));
+ this._pOneData[1] = Math.PI*2/(!this._iUsesCycle? 1 : orbit.y);
+ this._pOneData[2] = orbit.x*Math.PI*2;
+ if (this._iUsesPhase)
+ this._pOneData[3] = orbit.z*Math.PI/180;
+ }
+}
+
+export = ParticleOrbitNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleOscillatorNode.js b/lib/animators/nodes/ParticleOscillatorNode.js
new file mode 100755
index 000000000..e67ce1a21
--- /dev/null
+++ b/lib/animators/nodes/ParticleOscillatorNode.js
@@ -0,0 +1,85 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+var ParticleOscillatorState = require("awayjs-renderergl/lib/animators/states/ParticleOscillatorState");
+/**
+ * A particle animation node used to control the position of a particle over time using simple harmonic motion.
+ */
+var ParticleOscillatorNode = (function (_super) {
+ __extends(ParticleOscillatorNode, _super);
+ /**
+ * Creates a new ParticleOscillatorNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] oscillator Defines the default oscillator axis (x, y, z) and cycleDuration (w) of the node, used when in global mode.
+ */
+ function ParticleOscillatorNode(mode /*uint*/, oscillator) {
+ if (oscillator === void 0) { oscillator = null; }
+ _super.call(this, "ParticleOscillator", mode, 4);
+ this._pStateClass = ParticleOscillatorState;
+ this._iOscillator = oscillator || new Vector3D();
+ }
+ /**
+ * @inheritDoc
+ */
+ ParticleOscillatorNode.prototype.getAGALVertexCode = function (shaderObject, animationRegisterCache) {
+ var oscillatorRegister = (this._pMode == ParticlePropertiesMode.GLOBAL) ? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleOscillatorState.OSCILLATOR_INDEX, oscillatorRegister.index);
+ var temp = animationRegisterCache.getFreeVertexVectorTemp();
+ var dgree = new ShaderRegisterElement(temp.regName, temp.index, 0);
+ var sin = new ShaderRegisterElement(temp.regName, temp.index, 1);
+ var cos = new ShaderRegisterElement(temp.regName, temp.index, 2);
+ animationRegisterCache.addVertexTempUsages(temp, 1);
+ var temp2 = animationRegisterCache.getFreeVertexVectorTemp();
+ var distance = new ShaderRegisterElement(temp2.regName, temp2.index);
+ animationRegisterCache.removeVertexTempUsage(temp);
+ var code = "";
+ code += "mul " + dgree + "," + animationRegisterCache.vertexTime + "," + oscillatorRegister + ".w\n";
+ code += "sin " + sin + "," + dgree + "\n";
+ code += "mul " + distance + ".xyz," + sin + "," + oscillatorRegister + ".xyz\n";
+ code += "add " + animationRegisterCache.positionTarget + ".xyz," + distance + ".xyz," + animationRegisterCache.positionTarget + ".xyz\n";
+ if (animationRegisterCache.needVelocity) {
+ code += "cos " + cos + "," + dgree + "\n";
+ code += "mul " + distance + ".xyz," + cos + "," + oscillatorRegister + ".xyz\n";
+ code += "add " + animationRegisterCache.velocityTarget + ".xyz," + distance + ".xyz," + animationRegisterCache.velocityTarget + ".xyz\n";
+ }
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleOscillatorNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleOscillatorNode.prototype._iGeneratePropertyOfOneParticle = function (param) {
+ //(Vector3D.x,Vector3D.y,Vector3D.z) is oscillator axis, Vector3D.w is oscillator cycle duration
+ var drift = param[ParticleOscillatorNode.OSCILLATOR_VECTOR3D];
+ if (!drift)
+ throw (new Error("there is no " + ParticleOscillatorNode.OSCILLATOR_VECTOR3D + " in param!"));
+ this._pOneData[0] = drift.x;
+ this._pOneData[1] = drift.y;
+ this._pOneData[2] = drift.z;
+ if (drift.w <= 0)
+ throw (new Error("the cycle duration must greater than zero"));
+ this._pOneData[3] = Math.PI * 2 / drift.w;
+ };
+ /**
+ * Reference for ocsillator node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
object representing the axis (x,y,z) and cycle speed (w) of the motion on the particle.
+ */
+ ParticleOscillatorNode.OSCILLATOR_VECTOR3D = "OscillatorVector3D";
+ return ParticleOscillatorNode;
+})(ParticleNodeBase);
+module.exports = ParticleOscillatorNode;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/nodes/particleoscillatornode.ts"],"names":["ParticleOscillatorNode","ParticleOscillatorNode.constructor","ParticleOscillatorNode.getAGALVertexCode","ParticleOscillatorNode.getAnimationState","ParticleOscillatorNode._iGeneratePropertyOfOneParticle"],"mappings":"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","file":"animators/nodes/ParticleOscillatorNode.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\n\nimport ParticleProperties\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleProperties\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleNodeBase\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleNodeBase\");\nimport ParticleOscillatorState\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleOscillatorState\");\n\n/**\n * A particle animation node used to control the position of a particle over time using simple harmonic motion.\n */\nclass ParticleOscillatorNode extends ParticleNodeBase\n{\n\t/** @private */\n\tpublic _iOscillator:Vector3D;\n\n\t/**\n\t * Reference for ocsillator node properties on a single particle (when in local property mode).\n\t * Expects a <code>Vector3D</code> object representing the axis (x,y,z) and cycle speed (w) of the motion on the particle.\n\t */\n\tpublic static OSCILLATOR_VECTOR3D:string = \"OscillatorVector3D\";\n\n\t/**\n\t * Creates a new <code>ParticleOscillatorNode</code>\n\t *\n\t * @param               mode            Defines whether the mode of operation acts on local properties of a particle or global properties of the node.\n\t * @param    [optional] oscillator      Defines the default oscillator axis (x, y, z) and cycleDuration (w) of the node, used when in global mode.\n\t */\n\tconstructor(mode:number /*uint*/, oscillator:Vector3D = null)\n\t{\n\t\tsuper(\"ParticleOscillator\", mode, 4);\n\n\t\tthis._pStateClass = ParticleOscillatorState;\n\n\t\tthis._iOscillator = oscillator || new Vector3D();\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string\n\t{\n\t\tvar oscillatorRegister:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();\n\t\tanimationRegisterCache.setRegisterIndex(this, ParticleOscillatorState.OSCILLATOR_INDEX, oscillatorRegister.index);\n\t\tvar temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\tvar dgree:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 0);\n\t\tvar sin:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 1);\n\t\tvar cos:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 2);\n\t\tanimationRegisterCache.addVertexTempUsages(temp, 1);\n\t\tvar temp2:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\tvar distance:ShaderRegisterElement = new ShaderRegisterElement(temp2.regName, temp2.index);\n\t\tanimationRegisterCache.removeVertexTempUsage(temp);\n\n\t\tvar code:string = \"\";\n\t\tcode += \"mul \" + dgree + \",\" + animationRegisterCache.vertexTime + \",\" + oscillatorRegister + \".w\\n\";\n\t\tcode += \"sin \" + sin + \",\" + dgree + \"\\n\";\n\t\tcode += \"mul \" + distance + \".xyz,\" + sin + \",\" + oscillatorRegister + \".xyz\\n\";\n\t\tcode += \"add \" + animationRegisterCache.positionTarget + \".xyz,\" + distance + \".xyz,\" + animationRegisterCache.positionTarget + \".xyz\\n\";\n\n\t\tif (animationRegisterCache.needVelocity) {\n\t\t\tcode += \"cos \" + cos + \",\" + dgree + \"\\n\";\n\t\t\tcode += \"mul \" + distance + \".xyz,\" + cos + \",\" + oscillatorRegister + \".xyz\\n\";\n\t\t\tcode += \"add \" + animationRegisterCache.velocityTarget + \".xyz,\" + distance + \".xyz,\" + animationRegisterCache.velocityTarget + \".xyz\\n\";\n\t\t}\n\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAnimationState(animator:AnimatorBase):ParticleOscillatorState\n\t{\n\t\treturn <ParticleOscillatorState> animator.getAnimationState(this);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _iGeneratePropertyOfOneParticle(param:ParticleProperties)\n\t{\n\t\t//(Vector3D.x,Vector3D.y,Vector3D.z) is oscillator axis, Vector3D.w is oscillator cycle duration\n\t\tvar drift:Vector3D = param[ParticleOscillatorNode.OSCILLATOR_VECTOR3D];\n\t\tif (!drift)\n\t\t\tthrow(new Error(\"there is no \" + ParticleOscillatorNode.OSCILLATOR_VECTOR3D + \" in param!\"));\n\n\t\tthis._pOneData[0] = drift.x;\n\t\tthis._pOneData[1] = drift.y;\n\t\tthis._pOneData[2] = drift.z;\n\t\tif (drift.w <= 0)\n\t\t\tthrow(new Error(\"the cycle duration must greater than zero\"));\n\t\tthis._pOneData[3] = Math.PI*2/drift.w;\n\t}\n}\n\nexport = ParticleOscillatorNode;"]}
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleOscillatorNode.ts b/lib/animators/nodes/ParticleOscillatorNode.ts
new file mode 100644
index 000000000..f6fb73a2b
--- /dev/null
+++ b/lib/animators/nodes/ParticleOscillatorNode.ts
@@ -0,0 +1,100 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleOscillatorState = require("awayjs-renderergl/lib/animators/states/ParticleOscillatorState");
+
+/**
+ * A particle animation node used to control the position of a particle over time using simple harmonic motion.
+ */
+class ParticleOscillatorNode extends ParticleNodeBase
+{
+ /** @private */
+ public _iOscillator:Vector3D;
+
+ /**
+ * Reference for ocsillator node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
object representing the axis (x,y,z) and cycle speed (w) of the motion on the particle.
+ */
+ public static OSCILLATOR_VECTOR3D:string = "OscillatorVector3D";
+
+ /**
+ * Creates a new ParticleOscillatorNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] oscillator Defines the default oscillator axis (x, y, z) and cycleDuration (w) of the node, used when in global mode.
+ */
+ constructor(mode:number /*uint*/, oscillator:Vector3D = null)
+ {
+ super("ParticleOscillator", mode, 4);
+
+ this._pStateClass = ParticleOscillatorState;
+
+ this._iOscillator = oscillator || new Vector3D();
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ var oscillatorRegister:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleOscillatorState.OSCILLATOR_INDEX, oscillatorRegister.index);
+ var temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ var dgree:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 0);
+ var sin:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 1);
+ var cos:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 2);
+ animationRegisterCache.addVertexTempUsages(temp, 1);
+ var temp2:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ var distance:ShaderRegisterElement = new ShaderRegisterElement(temp2.regName, temp2.index);
+ animationRegisterCache.removeVertexTempUsage(temp);
+
+ var code:string = "";
+ code += "mul " + dgree + "," + animationRegisterCache.vertexTime + "," + oscillatorRegister + ".w\n";
+ code += "sin " + sin + "," + dgree + "\n";
+ code += "mul " + distance + ".xyz," + sin + "," + oscillatorRegister + ".xyz\n";
+ code += "add " + animationRegisterCache.positionTarget + ".xyz," + distance + ".xyz," + animationRegisterCache.positionTarget + ".xyz\n";
+
+ if (animationRegisterCache.needVelocity) {
+ code += "cos " + cos + "," + dgree + "\n";
+ code += "mul " + distance + ".xyz," + cos + "," + oscillatorRegister + ".xyz\n";
+ code += "add " + animationRegisterCache.velocityTarget + ".xyz," + distance + ".xyz," + animationRegisterCache.velocityTarget + ".xyz\n";
+ }
+
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):ParticleOscillatorState
+ {
+ return animator.getAnimationState(this);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iGeneratePropertyOfOneParticle(param:ParticleProperties)
+ {
+ //(Vector3D.x,Vector3D.y,Vector3D.z) is oscillator axis, Vector3D.w is oscillator cycle duration
+ var drift:Vector3D = param[ParticleOscillatorNode.OSCILLATOR_VECTOR3D];
+ if (!drift)
+ throw(new Error("there is no " + ParticleOscillatorNode.OSCILLATOR_VECTOR3D + " in param!"));
+
+ this._pOneData[0] = drift.x;
+ this._pOneData[1] = drift.y;
+ this._pOneData[2] = drift.z;
+ if (drift.w <= 0)
+ throw(new Error("the cycle duration must greater than zero"));
+ this._pOneData[3] = Math.PI*2/drift.w;
+ }
+}
+
+export = ParticleOscillatorNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticlePositionNode.js b/lib/animators/nodes/ParticlePositionNode.js
new file mode 100755
index 000000000..1c99e8232
--- /dev/null
+++ b/lib/animators/nodes/ParticlePositionNode.js
@@ -0,0 +1,62 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+var ParticlePositionState = require("awayjs-renderergl/lib/animators/states/ParticlePositionState");
+/**
+ * A particle animation node used to set the starting position of a particle.
+ */
+var ParticlePositionNode = (function (_super) {
+ __extends(ParticlePositionNode, _super);
+ /**
+ * Creates a new ParticlePositionNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] position Defines the default position of the particle when in global mode. Defaults to 0,0,0.
+ */
+ function ParticlePositionNode(mode /*uint*/, position) {
+ if (position === void 0) { position = null; }
+ _super.call(this, "ParticlePosition", mode, 3);
+ this._pStateClass = ParticlePositionState;
+ this._iPosition = position || new Vector3D();
+ }
+ /**
+ * @inheritDoc
+ */
+ ParticlePositionNode.prototype.getAGALVertexCode = function (shaderObject, animationRegisterCache) {
+ var positionAttribute = (this._pMode == ParticlePropertiesMode.GLOBAL) ? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticlePositionState.POSITION_INDEX, positionAttribute.index);
+ return "add " + animationRegisterCache.positionTarget + ".xyz," + positionAttribute + ".xyz," + animationRegisterCache.positionTarget + ".xyz\n";
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticlePositionNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticlePositionNode.prototype._iGeneratePropertyOfOneParticle = function (param) {
+ var offset = param[ParticlePositionNode.POSITION_VECTOR3D];
+ if (!offset)
+ throw (new Error("there is no " + ParticlePositionNode.POSITION_VECTOR3D + " in param!"));
+ this._pOneData[0] = offset.x;
+ this._pOneData[1] = offset.y;
+ this._pOneData[2] = offset.z;
+ };
+ /**
+ * Reference for position node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
object representing position of the particle.
+ */
+ ParticlePositionNode.POSITION_VECTOR3D = "PositionVector3D";
+ return ParticlePositionNode;
+})(ParticleNodeBase);
+module.exports = ParticlePositionNode;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9ub2Rlcy9wYXJ0aWNsZXBvc2l0aW9ubm9kZS50cyJdLCJuYW1lcyI6WyJQYXJ0aWNsZVBvc2l0aW9uTm9kZSIsIlBhcnRpY2xlUG9zaXRpb25Ob2RlLmNvbnN0cnVjdG9yIiwiUGFydGljbGVQb3NpdGlvbk5vZGUuZ2V0QUdBTFZlcnRleENvZGUiLCJQYXJ0aWNsZVBvc2l0aW9uTm9kZS5nZXRBbmltYXRpb25TdGF0ZSIsIlBhcnRpY2xlUG9zaXRpb25Ob2RlLl9pR2VuZXJhdGVQcm9wZXJ0eU9mT25lUGFydGljbGUiXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQU8sUUFBUSxXQUFpQixvQ0FBb0MsQ0FBQyxDQUFDO0FBUXRFLElBQU8sc0JBQXNCLFdBQWEsNkRBQTZELENBQUMsQ0FBQztBQUN6RyxJQUFPLGdCQUFnQixXQUFlLHdEQUF3RCxDQUFDLENBQUM7QUFDaEcsSUFBTyxxQkFBcUIsV0FBYSw4REFBOEQsQ0FBQyxDQUFDO0FBRXpHLEFBR0E7O0dBREc7SUFDRyxvQkFBb0I7SUFBU0EsVUFBN0JBLG9CQUFvQkEsVUFBeUJBO0lBV2xEQTs7Ozs7T0FLR0E7SUFDSEEsU0FqQktBLG9CQUFvQkEsQ0FpQmJBLElBQUlBLENBQVFBLFFBQURBLEFBQVNBLEVBQUVBLFFBQXdCQTtRQUF4QkMsd0JBQXdCQSxHQUF4QkEsZUFBd0JBO1FBRXpEQSxrQkFBTUEsa0JBQWtCQSxFQUFFQSxJQUFJQSxFQUFFQSxDQUFDQSxDQUFDQSxDQUFDQTtRQUVuQ0EsSUFBSUEsQ0FBQ0EsWUFBWUEsR0FBR0EscUJBQXFCQSxDQUFDQTtRQUUxQ0EsSUFBSUEsQ0FBQ0EsVUFBVUEsR0FBR0EsUUFBUUEsSUFBSUEsSUFBSUEsUUFBUUEsRUFBRUEsQ0FBQ0E7SUFDOUNBLENBQUNBO0lBRUREOztPQUVHQTtJQUNJQSxnREFBaUJBLEdBQXhCQSxVQUF5QkEsWUFBNkJBLEVBQUVBLHNCQUE2Q0E7UUFFcEdFLElBQUlBLGlCQUFpQkEsR0FBeUJBLENBQUNBLElBQUlBLENBQUNBLE1BQU1BLElBQUlBLHNCQUFzQkEsQ0FBQ0EsTUFBTUEsQ0FBQ0EsR0FBRUEsc0JBQXNCQSxDQUFDQSxxQkFBcUJBLEVBQUVBLEdBQUdBLHNCQUFzQkEsQ0FBQ0Esc0JBQXNCQSxFQUFFQSxDQUFDQTtRQUMvTEEsc0JBQXNCQSxDQUFDQSxnQkFBZ0JBLENBQUNBLElBQUlBLEVBQUVBLHFCQUFxQkEsQ0FBQ0EsY0FBY0EsRUFBRUEsaUJBQWlCQSxDQUFDQSxLQUFLQSxDQUFDQSxDQUFDQTtRQUU3R0EsTUFBTUEsQ0FBQ0EsTUFBTUEsR0FBR0Esc0JBQXNCQSxDQUFDQSxjQUFjQSxHQUFHQSxPQUFPQSxHQUFHQSxpQkFBaUJBLEdBQUdBLE9BQU9BLEdBQUdBLHNCQUFzQkEsQ0FBQ0EsY0FBY0EsR0FBR0EsUUFBUUEsQ0FBQ0E7SUFDbEpBLENBQUNBO0lBRURGOztPQUVHQTtJQUNJQSxnREFBaUJBLEdBQXhCQSxVQUF5QkEsUUFBcUJBO1FBRTdDRyxNQUFNQSxDQUF5QkEsUUFBUUEsQ0FBQ0EsaUJBQWlCQSxDQUFDQSxJQUFJQSxDQUFDQSxDQUFDQTtJQUNqRUEsQ0FBQ0E7SUFFREg7O09BRUdBO0lBQ0lBLDhEQUErQkEsR0FBdENBLFVBQXVDQSxLQUF3QkE7UUFFOURJLElBQUlBLE1BQU1BLEdBQVlBLEtBQUtBLENBQUNBLG9CQUFvQkEsQ0FBQ0EsaUJBQWlCQSxDQUFDQSxDQUFDQTtRQUNwRUEsRUFBRUEsQ0FBQ0EsQ0FBQ0EsQ0FBQ0EsTUFBTUEsQ0FBQ0E7WUFDWEEsTUFBS0EsQ0FBQ0EsSUFBSUEsS0FBS0EsQ0FBQ0EsY0FBY0EsR0FBR0Esb0JBQW9CQSxDQUFDQSxpQkFBaUJBLEdBQUdBLFlBQVlBLENBQUNBLENBQUNBLENBQUNBO1FBRTFGQSxJQUFJQSxDQUFDQSxTQUFTQSxDQUFDQSxDQUFDQSxDQUFDQSxHQUFHQSxNQUFNQSxDQUFDQSxDQUFDQSxDQUFDQTtRQUM3QkEsSUFBSUEsQ0FBQ0EsU0FBU0EsQ0FBQ0EsQ0FBQ0EsQ0FBQ0EsR0FBR0EsTUFBTUEsQ0FBQ0EsQ0FBQ0EsQ0FBQ0E7UUFDN0JBLElBQUlBLENBQUNBLFNBQVNBLENBQUNBLENBQUNBLENBQUNBLEdBQUdBLE1BQU1BLENBQUNBLENBQUNBLENBQUNBO0lBQzlCQSxDQUFDQTtJQXBEREo7OztPQUdHQTtJQUNXQSxzQ0FBaUJBLEdBQVVBLGtCQUFrQkEsQ0FBQ0E7SUFpRDdEQSwyQkFBQ0E7QUFBREEsQ0ExREEsQUEwRENBLEVBMURrQyxnQkFBZ0IsRUEwRGxEO0FBRUQsQUFBOEIsaUJBQXJCLG9CQUFvQixDQUFDIiwiZmlsZSI6ImFuaW1hdG9ycy9ub2Rlcy9QYXJ0aWNsZVBvc2l0aW9uTm9kZS5qcyIsInNvdXJjZVJvb3QiOiIvVXNlcnMvcm9iYmF0ZW1hbi9XZWJzdG9ybVByb2plY3RzL2F3YXlqcy1yZW5kZXJlcmdsLyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBWZWN0b3IzRFx0XHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLWNvcmUvbGliL2NvcmUvZ2VvbS9WZWN0b3IzRFwiKTtcblxuaW1wb3J0IEFuaW1hdG9yQmFzZVx0XHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1zdGFnZWdsL2xpYi9hbmltYXRvcnMvQW5pbWF0b3JCYXNlXCIpO1xuaW1wb3J0IEFuaW1hdGlvblJlZ2lzdGVyQ2FjaGVcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvYW5pbWF0b3JzL2RhdGEvQW5pbWF0aW9uUmVnaXN0ZXJDYWNoZVwiKTtcbmltcG9ydCBTaGFkZXJPYmplY3RCYXNlXHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1zdGFnZWdsL2xpYi9tYXRlcmlhbHMvY29tcGlsYXRpb24vU2hhZGVyT2JqZWN0QmFzZVwiKTtcbmltcG9ydCBTaGFkZXJSZWdpc3RlckVsZW1lbnRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvbWF0ZXJpYWxzL2NvbXBpbGF0aW9uL1NoYWRlclJlZ2lzdGVyRWxlbWVudFwiKTtcblxuaW1wb3J0IFBhcnRpY2xlUHJvcGVydGllc1x0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXJlbmRlcmVyZ2wvbGliL2FuaW1hdG9ycy9kYXRhL1BhcnRpY2xlUHJvcGVydGllc1wiKTtcbmltcG9ydCBQYXJ0aWNsZVByb3BlcnRpZXNNb2RlXHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXJlbmRlcmVyZ2wvbGliL2FuaW1hdG9ycy9kYXRhL1BhcnRpY2xlUHJvcGVydGllc01vZGVcIik7XG5pbXBvcnQgUGFydGljbGVOb2RlQmFzZVx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL25vZGVzL1BhcnRpY2xlTm9kZUJhc2VcIik7XG5pbXBvcnQgUGFydGljbGVQb3NpdGlvblN0YXRlXHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXJlbmRlcmVyZ2wvbGliL2FuaW1hdG9ycy9zdGF0ZXMvUGFydGljbGVQb3NpdGlvblN0YXRlXCIpO1xuXG4vKipcbiAqIEEgcGFydGljbGUgYW5pbWF0aW9uIG5vZGUgdXNlZCB0byBzZXQgdGhlIHN0YXJ0aW5nIHBvc2l0aW9uIG9mIGEgcGFydGljbGUuXG4gKi9cbmNsYXNzIFBhcnRpY2xlUG9zaXRpb25Ob2RlIGV4dGVuZHMgUGFydGljbGVOb2RlQmFzZVxue1xuXHQvKiogQHByaXZhdGUgKi9cblx0cHVibGljIF9pUG9zaXRpb246VmVjdG9yM0Q7XG5cblx0LyoqXG5cdCAqIFJlZmVyZW5jZSBmb3IgcG9zaXRpb24gbm9kZSBwcm9wZXJ0aWVzIG9uIGEgc2luZ2xlIHBhcnRpY2xlICh3aGVuIGluIGxvY2FsIHByb3BlcnR5IG1vZGUpLlxuXHQgKiBFeHBlY3RzIGEgPGNvZGU+VmVjdG9yM0Q8L2NvZGU+IG9iamVjdCByZXByZXNlbnRpbmcgcG9zaXRpb24gb2YgdGhlIHBhcnRpY2xlLlxuXHQgKi9cblx0cHVibGljIHN0YXRpYyBQT1NJVElPTl9WRUNUT1IzRDpzdHJpbmcgPSBcIlBvc2l0aW9uVmVjdG9yM0RcIjtcblxuXHQvKipcblx0ICogQ3JlYXRlcyBhIG5ldyA8Y29kZT5QYXJ0aWNsZVBvc2l0aW9uTm9kZTwvY29kZT5cblx0ICpcblx0ICogQHBhcmFtICAgICAgICAgICAgICAgbW9kZSAgICAgICAgICAgIERlZmluZXMgd2hldGhlciB0aGUgbW9kZSBvZiBvcGVyYXRpb24gYWN0cyBvbiBsb2NhbCBwcm9wZXJ0aWVzIG9mIGEgcGFydGljbGUgb3IgZ2xvYmFsIHByb3BlcnRpZXMgb2YgdGhlIG5vZGUuXG5cdCAqIEBwYXJhbSAgICBbb3B0aW9uYWxdIHBvc2l0aW9uICAgICAgICBEZWZpbmVzIHRoZSBkZWZhdWx0IHBvc2l0aW9uIG9mIHRoZSBwYXJ0aWNsZSB3aGVuIGluIGdsb2JhbCBtb2RlLiBEZWZhdWx0cyB0byAwLDAsMC5cblx0ICovXG5cdGNvbnN0cnVjdG9yKG1vZGU6bnVtYmVyIC8qdWludCovLCBwb3NpdGlvbjpWZWN0b3IzRCA9IG51bGwpXG5cdHtcblx0XHRzdXBlcihcIlBhcnRpY2xlUG9zaXRpb25cIiwgbW9kZSwgMyk7XG5cblx0XHR0aGlzLl9wU3RhdGVDbGFzcyA9IFBhcnRpY2xlUG9zaXRpb25TdGF0ZTtcblxuXHRcdHRoaXMuX2lQb3NpdGlvbiA9IHBvc2l0aW9uIHx8IG5ldyBWZWN0b3IzRCgpO1xuXHR9XG5cblx0LyoqXG5cdCAqIEBpbmhlcml0RG9jXG5cdCAqL1xuXHRwdWJsaWMgZ2V0QUdBTFZlcnRleENvZGUoc2hhZGVyT2JqZWN0OlNoYWRlck9iamVjdEJhc2UsIGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGU6QW5pbWF0aW9uUmVnaXN0ZXJDYWNoZSk6c3RyaW5nXG5cdHtcblx0XHR2YXIgcG9zaXRpb25BdHRyaWJ1dGU6U2hhZGVyUmVnaXN0ZXJFbGVtZW50ID0gKHRoaXMuX3BNb2RlID09IFBhcnRpY2xlUHJvcGVydGllc01vZGUuR0xPQkFMKT8gYW5pbWF0aW9uUmVnaXN0ZXJDYWNoZS5nZXRGcmVlVmVydGV4Q29uc3RhbnQoKSA6IGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGUuZ2V0RnJlZVZlcnRleEF0dHJpYnV0ZSgpO1xuXHRcdGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGUuc2V0UmVnaXN0ZXJJbmRleCh0aGlzLCBQYXJ0aWNsZVBvc2l0aW9uU3RhdGUuUE9TSVRJT05fSU5ERVgsIHBvc2l0aW9uQXR0cmlidXRlLmluZGV4KTtcblxuXHRcdHJldHVybiBcImFkZCBcIiArIGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGUucG9zaXRpb25UYXJnZXQgKyBcIi54eXosXCIgKyBwb3NpdGlvbkF0dHJpYnV0ZSArIFwiLnh5eixcIiArIGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGUucG9zaXRpb25UYXJnZXQgKyBcIi54eXpcXG5cIjtcblx0fVxuXG5cdC8qKlxuXHQgKiBAaW5oZXJpdERvY1xuXHQgKi9cblx0cHVibGljIGdldEFuaW1hdGlvblN0YXRlKGFuaW1hdG9yOkFuaW1hdG9yQmFzZSk6UGFydGljbGVQb3NpdGlvblN0YXRlXG5cdHtcblx0XHRyZXR1cm4gPFBhcnRpY2xlUG9zaXRpb25TdGF0ZT4gYW5pbWF0b3IuZ2V0QW5pbWF0aW9uU3RhdGUodGhpcyk7XG5cdH1cblxuXHQvKipcblx0ICogQGluaGVyaXREb2Ncblx0ICovXG5cdHB1YmxpYyBfaUdlbmVyYXRlUHJvcGVydHlPZk9uZVBhcnRpY2xlKHBhcmFtOlBhcnRpY2xlUHJvcGVydGllcylcblx0e1xuXHRcdHZhciBvZmZzZXQ6VmVjdG9yM0QgPSBwYXJhbVtQYXJ0aWNsZVBvc2l0aW9uTm9kZS5QT1NJVElPTl9WRUNUT1IzRF07XG5cdFx0aWYgKCFvZmZzZXQpXG5cdFx0XHR0aHJvdyhuZXcgRXJyb3IoXCJ0aGVyZSBpcyBubyBcIiArIFBhcnRpY2xlUG9zaXRpb25Ob2RlLlBPU0lUSU9OX1ZFQ1RPUjNEICsgXCIgaW4gcGFyYW0hXCIpKTtcblxuXHRcdHRoaXMuX3BPbmVEYXRhWzBdID0gb2Zmc2V0Lng7XG5cdFx0dGhpcy5fcE9uZURhdGFbMV0gPSBvZmZzZXQueTtcblx0XHR0aGlzLl9wT25lRGF0YVsyXSA9IG9mZnNldC56O1xuXHR9XG59XG5cbmV4cG9ydCA9IFBhcnRpY2xlUG9zaXRpb25Ob2RlOyJdfQ==
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticlePositionNode.ts b/lib/animators/nodes/ParticlePositionNode.ts
new file mode 100644
index 000000000..e811771a6
--- /dev/null
+++ b/lib/animators/nodes/ParticlePositionNode.ts
@@ -0,0 +1,76 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticlePositionState = require("awayjs-renderergl/lib/animators/states/ParticlePositionState");
+
+/**
+ * A particle animation node used to set the starting position of a particle.
+ */
+class ParticlePositionNode extends ParticleNodeBase
+{
+ /** @private */
+ public _iPosition:Vector3D;
+
+ /**
+ * Reference for position node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
object representing position of the particle.
+ */
+ public static POSITION_VECTOR3D:string = "PositionVector3D";
+
+ /**
+ * Creates a new ParticlePositionNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] position Defines the default position of the particle when in global mode. Defaults to 0,0,0.
+ */
+ constructor(mode:number /*uint*/, position:Vector3D = null)
+ {
+ super("ParticlePosition", mode, 3);
+
+ this._pStateClass = ParticlePositionState;
+
+ this._iPosition = position || new Vector3D();
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ var positionAttribute:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticlePositionState.POSITION_INDEX, positionAttribute.index);
+
+ return "add " + animationRegisterCache.positionTarget + ".xyz," + positionAttribute + ".xyz," + animationRegisterCache.positionTarget + ".xyz\n";
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):ParticlePositionState
+ {
+ return animator.getAnimationState(this);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iGeneratePropertyOfOneParticle(param:ParticleProperties)
+ {
+ var offset:Vector3D = param[ParticlePositionNode.POSITION_VECTOR3D];
+ if (!offset)
+ throw(new Error("there is no " + ParticlePositionNode.POSITION_VECTOR3D + " in param!"));
+
+ this._pOneData[0] = offset.x;
+ this._pOneData[1] = offset.y;
+ this._pOneData[2] = offset.z;
+ }
+}
+
+export = ParticlePositionNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleRotateToHeadingNode.js b/lib/animators/nodes/ParticleRotateToHeadingNode.js
new file mode 100755
index 000000000..dd7a1619c
--- /dev/null
+++ b/lib/animators/nodes/ParticleRotateToHeadingNode.js
@@ -0,0 +1,163 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+var ParticleRotateToHeadingState = require("awayjs-renderergl/lib/animators/states/ParticleRotateToHeadingState");
+/**
+ * A particle animation node used to control the rotation of a particle to match its heading vector.
+ */
+var ParticleRotateToHeadingNode = (function (_super) {
+ __extends(ParticleRotateToHeadingNode, _super);
+ /**
+ * Creates a new ParticleBillboardNode
+ */
+ function ParticleRotateToHeadingNode() {
+ _super.call(this, "ParticleRotateToHeading", ParticlePropertiesMode.GLOBAL, 0, 3);
+ this._pStateClass = ParticleRotateToHeadingState;
+ }
+ /**
+ * @inheritDoc
+ */
+ ParticleRotateToHeadingNode.prototype.getAGALVertexCode = function (shaderObject, animationRegisterCache) {
+ var code = "";
+ var len = animationRegisterCache.rotationRegisters.length;
+ var i /*int*/;
+ if (animationRegisterCache.hasBillboard) {
+ var temp1 = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp1, 1);
+ var temp2 = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp2, 1);
+ var temp3 = animationRegisterCache.getFreeVertexVectorTemp();
+ var rotationMatrixRegister = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleRotateToHeadingState.MATRIX_INDEX, rotationMatrixRegister.index);
+ animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.removeVertexTempUsage(temp1);
+ animationRegisterCache.removeVertexTempUsage(temp2);
+ //process the velocity
+ code += "m33 " + temp1 + ".xyz," + animationRegisterCache.velocityTarget + ".xyz," + rotationMatrixRegister + "\n";
+ code += "mov " + temp3 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp3 + ".xy," + temp1 + ".xy\n";
+ code += "nrm " + temp3 + ".xyz," + temp3 + ".xyz\n";
+ //temp3.x=cos,temp3.y=sin
+ //only process z axis
+ code += "mov " + temp2 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp2 + ".x," + temp3 + ".y\n";
+ code += "mov " + temp2 + ".y," + temp3 + ".x\n";
+ code += "mov " + temp1 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp1 + ".x," + temp3 + ".x\n";
+ code += "neg " + temp1 + ".y," + temp3 + ".y\n";
+ code += "mov " + temp3 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp3 + ".z," + animationRegisterCache.vertexOneConst + "\n";
+ code += "m33 " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz," + temp1 + "\n";
+ for (i = 0; i < len; i++)
+ code += "m33 " + animationRegisterCache.rotationRegisters[i] + ".xyz," + animationRegisterCache.rotationRegisters[i] + "," + temp1 + "\n";
+ }
+ else {
+ var nrmVel = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(nrmVel, 1);
+ var xAxis = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(xAxis, 1);
+ var R = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(R, 1);
+ var R_rev = animationRegisterCache.getFreeVertexVectorTemp();
+ var cos = new ShaderRegisterElement(R.regName, R.index, 3);
+ var sin = new ShaderRegisterElement(R_rev.regName, R_rev.index, 3);
+ var cos2 = new ShaderRegisterElement(nrmVel.regName, nrmVel.index, 3);
+ var tempSingle = sin;
+ animationRegisterCache.removeVertexTempUsage(nrmVel);
+ animationRegisterCache.removeVertexTempUsage(xAxis);
+ animationRegisterCache.removeVertexTempUsage(R);
+ code += "mov " + xAxis + ".x," + animationRegisterCache.vertexOneConst + "\n";
+ code += "mov " + xAxis + ".yz," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "nrm " + nrmVel + ".xyz," + animationRegisterCache.velocityTarget + ".xyz\n";
+ code += "dp3 " + cos2 + "," + nrmVel + ".xyz," + xAxis + ".xyz\n";
+ code += "crs " + nrmVel + ".xyz," + xAxis + ".xyz," + nrmVel + ".xyz\n";
+ code += "nrm " + nrmVel + ".xyz," + nrmVel + ".xyz\n";
+ //use R as temp to judge if nrm is (0,0,0).
+ //if nrm is (0,0,0) ,change it to (0,0,1).
+ code += "dp3 " + R + ".x," + nrmVel + ".xyz," + nrmVel + ".xyz\n";
+ code += "sge " + R + ".x," + animationRegisterCache.vertexZeroConst + "," + R + ".x\n";
+ code += "add " + nrmVel + ".z," + R + ".x," + nrmVel + ".z\n";
+ code += "add " + tempSingle + "," + cos2 + "," + animationRegisterCache.vertexOneConst + "\n";
+ code += "div " + tempSingle + "," + tempSingle + "," + animationRegisterCache.vertexTwoConst + "\n";
+ code += "sqt " + cos + "," + tempSingle + "\n";
+ code += "sub " + tempSingle + "," + animationRegisterCache.vertexOneConst + "," + cos2 + "\n";
+ code += "div " + tempSingle + "," + tempSingle + "," + animationRegisterCache.vertexTwoConst + "\n";
+ code += "sqt " + sin + "," + tempSingle + "\n";
+ code += "mul " + R + ".xyz," + sin + "," + nrmVel + ".xyz\n";
+ //use cos as R.w
+ code += "mul " + R_rev + ".xyz," + sin + "," + nrmVel + ".xyz\n";
+ code += "neg " + R_rev + ".xyz," + R_rev + ".xyz\n";
+ //use cos as R_rev.w
+ //nrmVel and xAxis are used as temp register
+ code += "crs " + nrmVel + ".xyz," + R + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz\n";
+ //use cos as R.w
+ code += "mul " + xAxis + ".xyz," + cos + "," + animationRegisterCache.scaleAndRotateTarget + ".xyz\n";
+ code += "add " + nrmVel + ".xyz," + nrmVel + ".xyz," + xAxis + ".xyz\n";
+ code += "dp3 " + xAxis + ".w," + R + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz\n";
+ code += "neg " + nrmVel + ".w," + xAxis + ".w\n";
+ code += "crs " + R + ".xyz," + nrmVel + ".xyz," + R_rev + ".xyz\n";
+ //code += "mul " + xAxis + ".xyzw," + nrmVel + ".xyzw," +R_rev + ".w\n";
+ code += "mul " + xAxis + ".xyzw," + nrmVel + ".xyzw," + cos + "\n";
+ code += "add " + R + ".xyz," + R + ".xyz," + xAxis + ".xyz\n";
+ code += "mul " + xAxis + ".xyz," + nrmVel + ".w," + R_rev + ".xyz\n";
+ code += "add " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + R + ".xyz," + xAxis + ".xyz\n";
+ for (i = 0; i < len; i++) {
+ //just repeat the calculate above
+ //because of the limited registers, no need to optimise
+ code += "mov " + xAxis + ".x," + animationRegisterCache.vertexOneConst + "\n";
+ code += "mov " + xAxis + ".yz," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "nrm " + nrmVel + ".xyz," + animationRegisterCache.velocityTarget + ".xyz\n";
+ code += "dp3 " + cos2 + "," + nrmVel + ".xyz," + xAxis + ".xyz\n";
+ code += "crs " + nrmVel + ".xyz," + xAxis + ".xyz," + nrmVel + ".xyz\n";
+ code += "nrm " + nrmVel + ".xyz," + nrmVel + ".xyz\n";
+ code += "dp3 " + R + ".x," + nrmVel + ".xyz," + nrmVel + ".xyz\n";
+ code += "sge " + R + ".x," + animationRegisterCache.vertexZeroConst + "," + R + ".x\n";
+ code += "add " + nrmVel + ".z," + R + ".x," + nrmVel + ".z\n";
+ code += "add " + tempSingle + "," + cos2 + "," + animationRegisterCache.vertexOneConst + "\n";
+ code += "div " + tempSingle + "," + tempSingle + "," + animationRegisterCache.vertexTwoConst + "\n";
+ code += "sqt " + cos + "," + tempSingle + "\n";
+ code += "sub " + tempSingle + "," + animationRegisterCache.vertexOneConst + "," + cos2 + "\n";
+ code += "div " + tempSingle + "," + tempSingle + "," + animationRegisterCache.vertexTwoConst + "\n";
+ code += "sqt " + sin + "," + tempSingle + "\n";
+ code += "mul " + R + ".xyz," + sin + "," + nrmVel + ".xyz\n";
+ code += "mul " + R_rev + ".xyz," + sin + "," + nrmVel + ".xyz\n";
+ code += "neg " + R_rev + ".xyz," + R_rev + ".xyz\n";
+ code += "crs " + nrmVel + ".xyz," + R + ".xyz," + animationRegisterCache.rotationRegisters[i] + ".xyz\n";
+ code += "mul " + xAxis + ".xyz," + cos + "," + animationRegisterCache.rotationRegisters[i] + ".xyz\n";
+ code += "add " + nrmVel + ".xyz," + nrmVel + ".xyz," + xAxis + ".xyz\n";
+ code += "dp3 " + xAxis + ".w," + R + ".xyz," + animationRegisterCache.rotationRegisters[i] + ".xyz\n";
+ code += "neg " + nrmVel + ".w," + xAxis + ".w\n";
+ code += "crs " + R + ".xyz," + nrmVel + ".xyz," + R_rev + ".xyz\n";
+ code += "mul " + xAxis + ".xyzw," + nrmVel + ".xyzw," + cos + "\n";
+ code += "add " + R + ".xyz," + R + ".xyz," + xAxis + ".xyz\n";
+ code += "mul " + xAxis + ".xyz," + nrmVel + ".w," + R_rev + ".xyz\n";
+ code += "add " + animationRegisterCache.rotationRegisters[i] + ".xyz," + R + ".xyz," + xAxis + ".xyz\n";
+ }
+ }
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleRotateToHeadingNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleRotateToHeadingNode.prototype._iProcessAnimationSetting = function (particleAnimationSet) {
+ particleAnimationSet.needVelocity = true;
+ };
+ return ParticleRotateToHeadingNode;
+})(ParticleNodeBase);
+module.exports = ParticleRotateToHeadingNode;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/nodes/particlerotatetoheadingnode.ts"],"names":["ParticleRotateToHeadingNode","ParticleRotateToHeadingNode.constructor","ParticleRotateToHeadingNode.getAGALVertexCode","ParticleRotateToHeadingNode.getAnimationState","ParticleRotateToHeadingNode._iProcessAnimationSetting"],"mappings":"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","file":"animators/nodes/ParticleRotateToHeadingNode.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\n\nimport ParticleAnimationSet\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimationSet\");\nimport ParticleProperties\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleProperties\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleNodeBase\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleNodeBase\");\nimport ParticleRotateToHeadingState\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleRotateToHeadingState\");\n\n/**\n * A particle animation node used to control the rotation of a particle to match its heading vector.\n */\nclass ParticleRotateToHeadingNode extends ParticleNodeBase\n{\n\t/**\n\t * Creates a new <code>ParticleBillboardNode</code>\n\t */\n\tconstructor()\n\t{\n\t\tsuper(\"ParticleRotateToHeading\", ParticlePropertiesMode.GLOBAL, 0, 3);\n\n\t\tthis._pStateClass = ParticleRotateToHeadingState;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string\n\t{\n\t\tvar code:string = \"\";\n\t\tvar len:number /*int*/ = animationRegisterCache.rotationRegisters.length;\n\t\tvar i:number /*int*/;\n\t\tif (animationRegisterCache.hasBillboard) {\n\t\t\tvar temp1:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\t\tanimationRegisterCache.addVertexTempUsages(temp1, 1);\n\t\t\tvar temp2:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\t\tanimationRegisterCache.addVertexTempUsages(temp2, 1);\n\t\t\tvar temp3:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\n\t\t\tvar rotationMatrixRegister:ShaderRegisterElement = animationRegisterCache.getFreeVertexConstant();\n\t\t\tanimationRegisterCache.setRegisterIndex(this, ParticleRotateToHeadingState.MATRIX_INDEX, rotationMatrixRegister.index);\n\t\t\tanimationRegisterCache.getFreeVertexConstant();\n\t\t\tanimationRegisterCache.getFreeVertexConstant();\n\t\t\tanimationRegisterCache.getFreeVertexConstant();\n\n\t\t\tanimationRegisterCache.removeVertexTempUsage(temp1);\n\t\t\tanimationRegisterCache.removeVertexTempUsage(temp2);\n\n\t\t\t//process the velocity\n\t\t\tcode += \"m33 \" + temp1 + \".xyz,\" + animationRegisterCache.velocityTarget + \".xyz,\" + rotationMatrixRegister + \"\\n\";\n\n\t\t\tcode += \"mov \" + temp3 + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"mov \" + temp3 + \".xy,\" + temp1 + \".xy\\n\";\n\t\t\tcode += \"nrm \" + temp3 + \".xyz,\" + temp3 + \".xyz\\n\";\n\n\t\t\t//temp3.x=cos,temp3.y=sin\n\t\t\t//only process z axis\n\t\t\tcode += \"mov \" + temp2 + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"mov \" + temp2 + \".x,\" + temp3 + \".y\\n\";\n\t\t\tcode += \"mov \" + temp2 + \".y,\" + temp3 + \".x\\n\";\n\t\t\tcode += \"mov \" + temp1 + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"mov \" + temp1 + \".x,\" + temp3 + \".x\\n\";\n\t\t\tcode += \"neg \" + temp1 + \".y,\" + temp3 + \".y\\n\";\n\t\t\tcode += \"mov \" + temp3 + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"mov \" + temp3 + \".z,\" + animationRegisterCache.vertexOneConst + \"\\n\";\n\t\t\tcode += \"m33 \" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + temp1 + \"\\n\";\n\t\t\tfor (i = 0; i < len; i++)\n\t\t\t\tcode += \"m33 \" + animationRegisterCache.rotationRegisters[i] + \".xyz,\" + animationRegisterCache.rotationRegisters[i] + \",\" + temp1 + \"\\n\";\n\t\t} else {\n\t\t\tvar nrmVel:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\t\tanimationRegisterCache.addVertexTempUsages(nrmVel, 1);\n\n\t\t\tvar xAxis:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\t\tanimationRegisterCache.addVertexTempUsages(xAxis, 1);\n\n\t\t\tvar R:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\t\tanimationRegisterCache.addVertexTempUsages(R, 1);\n\t\t\tvar R_rev:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\t\tvar cos:ShaderRegisterElement = new ShaderRegisterElement(R.regName, R.index, 3);\n\t\t\tvar sin:ShaderRegisterElement = new ShaderRegisterElement(R_rev.regName, R_rev.index, 3);\n\t\t\tvar cos2:ShaderRegisterElement = new ShaderRegisterElement(nrmVel.regName, nrmVel.index, 3);\n\t\t\tvar tempSingle:ShaderRegisterElement = sin;\n\n\t\t\tanimationRegisterCache.removeVertexTempUsage(nrmVel);\n\t\t\tanimationRegisterCache.removeVertexTempUsage(xAxis);\n\t\t\tanimationRegisterCache.removeVertexTempUsage(R);\n\n\t\t\tcode += \"mov \" + xAxis + \".x,\" + animationRegisterCache.vertexOneConst + \"\\n\";\n\t\t\tcode += \"mov \" + xAxis + \".yz,\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\n\t\t\tcode += \"nrm \" + nrmVel + \".xyz,\" + animationRegisterCache.velocityTarget + \".xyz\\n\";\n\t\t\tcode += \"dp3 \" + cos2 + \",\" + nrmVel + \".xyz,\" + xAxis + \".xyz\\n\";\n\t\t\tcode += \"crs \" + nrmVel + \".xyz,\" + xAxis + \".xyz,\" + nrmVel + \".xyz\\n\";\n\t\t\tcode += \"nrm \" + nrmVel + \".xyz,\" + nrmVel + \".xyz\\n\";\n\t\t\t//use R as temp to judge if nrm is (0,0,0).\n\t\t\t//if nrm is (0,0,0) ,change it to (0,0,1).\n\t\t\tcode += \"dp3 \" + R + \".x,\" + nrmVel + \".xyz,\" + nrmVel + \".xyz\\n\";\n\t\t\tcode += \"sge \" + R + \".x,\" + animationRegisterCache.vertexZeroConst + \",\" + R + \".x\\n\";\n\t\t\tcode += \"add \" + nrmVel + \".z,\" + R + \".x,\" + nrmVel + \".z\\n\";\n\n\t\t\tcode += \"add \" + tempSingle + \",\" + cos2 + \",\" + animationRegisterCache.vertexOneConst + \"\\n\";\n\t\t\tcode += \"div \" + tempSingle + \",\" + tempSingle + \",\" + animationRegisterCache.vertexTwoConst + \"\\n\";\n\t\t\tcode += \"sqt \" + cos + \",\" + tempSingle + \"\\n\";\n\n\t\t\tcode += \"sub \" + tempSingle + \",\" + animationRegisterCache.vertexOneConst + \",\" + cos2 + \"\\n\";\n\t\t\tcode += \"div \" + tempSingle + \",\" + tempSingle + \",\" + animationRegisterCache.vertexTwoConst + \"\\n\";\n\t\t\tcode += \"sqt \" + sin + \",\" + tempSingle + \"\\n\";\n\n\t\t\tcode += \"mul \" + R + \".xyz,\" + sin + \",\" + nrmVel + \".xyz\\n\";\n\n\t\t\t//use cos as R.w\n\n\t\t\tcode += \"mul \" + R_rev + \".xyz,\" + sin + \",\" + nrmVel + \".xyz\\n\";\n\t\t\tcode += \"neg \" + R_rev + \".xyz,\" + R_rev + \".xyz\\n\";\n\n\t\t\t//use cos as R_rev.w\n\n\t\t\t//nrmVel and xAxis are used as temp register\n\t\t\tcode += \"crs \" + nrmVel + \".xyz,\" + R + \".xyz,\" + animationRegisterCache.scaleAndRotateTarget + \".xyz\\n\";\n\n\t\t\t//use cos as R.w\n\t\t\tcode += \"mul \" + xAxis + \".xyz,\" + cos + \",\" + animationRegisterCache.scaleAndRotateTarget + \".xyz\\n\";\n\t\t\tcode += \"add \" + nrmVel + \".xyz,\" + nrmVel + \".xyz,\" + xAxis + \".xyz\\n\";\n\t\t\tcode += \"dp3 \" + xAxis + \".w,\" + R + \".xyz,\" + animationRegisterCache.scaleAndRotateTarget + \".xyz\\n\";\n\t\t\tcode += \"neg \" + nrmVel + \".w,\" + xAxis + \".w\\n\";\n\n\t\t\tcode += \"crs \" + R + \".xyz,\" + nrmVel + \".xyz,\" + R_rev + \".xyz\\n\";\n\t\t\t//code += \"mul \" + xAxis + \".xyzw,\" + nrmVel + \".xyzw,\" +R_rev + \".w\\n\";\n\t\t\tcode += \"mul \" + xAxis + \".xyzw,\" + nrmVel + \".xyzw,\" + cos + \"\\n\";\n\t\t\tcode += \"add \" + R + \".xyz,\" + R + \".xyz,\" + xAxis + \".xyz\\n\";\n\t\t\tcode += \"mul \" + xAxis + \".xyz,\" + nrmVel + \".w,\" + R_rev + \".xyz\\n\";\n\n\t\t\tcode += \"add \" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + R + \".xyz,\" + xAxis + \".xyz\\n\";\n\n\t\t\tfor (i = 0; i < len; i++) {\n\t\t\t\t//just repeat the calculate above\n\t\t\t\t//because of the limited registers, no need to optimise\n\t\t\t\tcode += \"mov \" + xAxis + \".x,\" + animationRegisterCache.vertexOneConst + \"\\n\";\n\t\t\t\tcode += \"mov \" + xAxis + \".yz,\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\t\tcode += \"nrm \" + nrmVel + \".xyz,\" + animationRegisterCache.velocityTarget + \".xyz\\n\";\n\t\t\t\tcode += \"dp3 \" + cos2 + \",\" + nrmVel + \".xyz,\" + xAxis + \".xyz\\n\";\n\t\t\t\tcode += \"crs \" + nrmVel + \".xyz,\" + xAxis + \".xyz,\" + nrmVel + \".xyz\\n\";\n\t\t\t\tcode += \"nrm \" + nrmVel + \".xyz,\" + nrmVel + \".xyz\\n\";\n\t\t\t\tcode += \"dp3 \" + R + \".x,\" + nrmVel + \".xyz,\" + nrmVel + \".xyz\\n\";\n\t\t\t\tcode += \"sge \" + R + \".x,\" + animationRegisterCache.vertexZeroConst + \",\" + R + \".x\\n\";\n\t\t\t\tcode += \"add \" + nrmVel + \".z,\" + R + \".x,\" + nrmVel + \".z\\n\";\n\t\t\t\tcode += \"add \" + tempSingle + \",\" + cos2 + \",\" + animationRegisterCache.vertexOneConst + \"\\n\";\n\t\t\t\tcode += \"div \" + tempSingle + \",\" + tempSingle + \",\" + animationRegisterCache.vertexTwoConst + \"\\n\";\n\t\t\t\tcode += \"sqt \" + cos + \",\" + tempSingle + \"\\n\";\n\t\t\t\tcode += \"sub \" + tempSingle + \",\" + animationRegisterCache.vertexOneConst + \",\" + cos2 + \"\\n\";\n\t\t\t\tcode += \"div \" + tempSingle + \",\" + tempSingle + \",\" + animationRegisterCache.vertexTwoConst + \"\\n\";\n\t\t\t\tcode += \"sqt \" + sin + \",\" + tempSingle + \"\\n\";\n\t\t\t\tcode += \"mul \" + R + \".xyz,\" + sin + \",\" + nrmVel + \".xyz\\n\";\n\t\t\t\tcode += \"mul \" + R_rev + \".xyz,\" + sin + \",\" + nrmVel + \".xyz\\n\";\n\t\t\t\tcode += \"neg \" + R_rev + \".xyz,\" + R_rev + \".xyz\\n\";\n\t\t\t\tcode += \"crs \" + nrmVel + \".xyz,\" + R + \".xyz,\" + animationRegisterCache.rotationRegisters[i] + \".xyz\\n\";\n\t\t\t\tcode += \"mul \" + xAxis + \".xyz,\" + cos + \",\" + animationRegisterCache.rotationRegisters[i] + \".xyz\\n\";\n\t\t\t\tcode += \"add \" + nrmVel + \".xyz,\" + nrmVel + \".xyz,\" + xAxis + \".xyz\\n\";\n\t\t\t\tcode += \"dp3 \" + xAxis + \".w,\" + R + \".xyz,\" + animationRegisterCache.rotationRegisters[i] + \".xyz\\n\";\n\t\t\t\tcode += \"neg \" + nrmVel + \".w,\" + xAxis + \".w\\n\";\n\t\t\t\tcode += \"crs \" + R + \".xyz,\" + nrmVel + \".xyz,\" + R_rev + \".xyz\\n\";\n\t\t\t\tcode += \"mul \" + xAxis + \".xyzw,\" + nrmVel + \".xyzw,\" + cos + \"\\n\";\n\t\t\t\tcode += \"add \" + R + \".xyz,\" + R + \".xyz,\" + xAxis + \".xyz\\n\";\n\t\t\t\tcode += \"mul \" + xAxis + \".xyz,\" + nrmVel + \".w,\" + R_rev + \".xyz\\n\";\n\t\t\t\tcode += \"add \" + animationRegisterCache.rotationRegisters[i] + \".xyz,\" + R + \".xyz,\" + xAxis + \".xyz\\n\";\n\t\t\t}\n\n\t\t}\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAnimationState(animator:AnimatorBase):ParticleRotateToHeadingState\n\t{\n\t\treturn <ParticleRotateToHeadingState> animator.getAnimationState(this);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _iProcessAnimationSetting(particleAnimationSet:ParticleAnimationSet)\n\t{\n\t\tparticleAnimationSet.needVelocity = true;\n\t}\n}\n\nexport = ParticleRotateToHeadingNode;"]}
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleRotateToHeadingNode.ts b/lib/animators/nodes/ParticleRotateToHeadingNode.ts
new file mode 100644
index 000000000..f9ee42d93
--- /dev/null
+++ b/lib/animators/nodes/ParticleRotateToHeadingNode.ts
@@ -0,0 +1,193 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+
+import ParticleAnimationSet = require("awayjs-renderergl/lib/animators/ParticleAnimationSet");
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleRotateToHeadingState = require("awayjs-renderergl/lib/animators/states/ParticleRotateToHeadingState");
+
+/**
+ * A particle animation node used to control the rotation of a particle to match its heading vector.
+ */
+class ParticleRotateToHeadingNode extends ParticleNodeBase
+{
+ /**
+ * Creates a new ParticleBillboardNode
+ */
+ constructor()
+ {
+ super("ParticleRotateToHeading", ParticlePropertiesMode.GLOBAL, 0, 3);
+
+ this._pStateClass = ParticleRotateToHeadingState;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ var code:string = "";
+ var len:number /*int*/ = animationRegisterCache.rotationRegisters.length;
+ var i:number /*int*/;
+ if (animationRegisterCache.hasBillboard) {
+ var temp1:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp1, 1);
+ var temp2:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp2, 1);
+ var temp3:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+
+ var rotationMatrixRegister:ShaderRegisterElement = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleRotateToHeadingState.MATRIX_INDEX, rotationMatrixRegister.index);
+ animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.getFreeVertexConstant();
+
+ animationRegisterCache.removeVertexTempUsage(temp1);
+ animationRegisterCache.removeVertexTempUsage(temp2);
+
+ //process the velocity
+ code += "m33 " + temp1 + ".xyz," + animationRegisterCache.velocityTarget + ".xyz," + rotationMatrixRegister + "\n";
+
+ code += "mov " + temp3 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp3 + ".xy," + temp1 + ".xy\n";
+ code += "nrm " + temp3 + ".xyz," + temp3 + ".xyz\n";
+
+ //temp3.x=cos,temp3.y=sin
+ //only process z axis
+ code += "mov " + temp2 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp2 + ".x," + temp3 + ".y\n";
+ code += "mov " + temp2 + ".y," + temp3 + ".x\n";
+ code += "mov " + temp1 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp1 + ".x," + temp3 + ".x\n";
+ code += "neg " + temp1 + ".y," + temp3 + ".y\n";
+ code += "mov " + temp3 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp3 + ".z," + animationRegisterCache.vertexOneConst + "\n";
+ code += "m33 " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz," + temp1 + "\n";
+ for (i = 0; i < len; i++)
+ code += "m33 " + animationRegisterCache.rotationRegisters[i] + ".xyz," + animationRegisterCache.rotationRegisters[i] + "," + temp1 + "\n";
+ } else {
+ var nrmVel:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(nrmVel, 1);
+
+ var xAxis:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(xAxis, 1);
+
+ var R:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(R, 1);
+ var R_rev:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ var cos:ShaderRegisterElement = new ShaderRegisterElement(R.regName, R.index, 3);
+ var sin:ShaderRegisterElement = new ShaderRegisterElement(R_rev.regName, R_rev.index, 3);
+ var cos2:ShaderRegisterElement = new ShaderRegisterElement(nrmVel.regName, nrmVel.index, 3);
+ var tempSingle:ShaderRegisterElement = sin;
+
+ animationRegisterCache.removeVertexTempUsage(nrmVel);
+ animationRegisterCache.removeVertexTempUsage(xAxis);
+ animationRegisterCache.removeVertexTempUsage(R);
+
+ code += "mov " + xAxis + ".x," + animationRegisterCache.vertexOneConst + "\n";
+ code += "mov " + xAxis + ".yz," + animationRegisterCache.vertexZeroConst + "\n";
+
+ code += "nrm " + nrmVel + ".xyz," + animationRegisterCache.velocityTarget + ".xyz\n";
+ code += "dp3 " + cos2 + "," + nrmVel + ".xyz," + xAxis + ".xyz\n";
+ code += "crs " + nrmVel + ".xyz," + xAxis + ".xyz," + nrmVel + ".xyz\n";
+ code += "nrm " + nrmVel + ".xyz," + nrmVel + ".xyz\n";
+ //use R as temp to judge if nrm is (0,0,0).
+ //if nrm is (0,0,0) ,change it to (0,0,1).
+ code += "dp3 " + R + ".x," + nrmVel + ".xyz," + nrmVel + ".xyz\n";
+ code += "sge " + R + ".x," + animationRegisterCache.vertexZeroConst + "," + R + ".x\n";
+ code += "add " + nrmVel + ".z," + R + ".x," + nrmVel + ".z\n";
+
+ code += "add " + tempSingle + "," + cos2 + "," + animationRegisterCache.vertexOneConst + "\n";
+ code += "div " + tempSingle + "," + tempSingle + "," + animationRegisterCache.vertexTwoConst + "\n";
+ code += "sqt " + cos + "," + tempSingle + "\n";
+
+ code += "sub " + tempSingle + "," + animationRegisterCache.vertexOneConst + "," + cos2 + "\n";
+ code += "div " + tempSingle + "," + tempSingle + "," + animationRegisterCache.vertexTwoConst + "\n";
+ code += "sqt " + sin + "," + tempSingle + "\n";
+
+ code += "mul " + R + ".xyz," + sin + "," + nrmVel + ".xyz\n";
+
+ //use cos as R.w
+
+ code += "mul " + R_rev + ".xyz," + sin + "," + nrmVel + ".xyz\n";
+ code += "neg " + R_rev + ".xyz," + R_rev + ".xyz\n";
+
+ //use cos as R_rev.w
+
+ //nrmVel and xAxis are used as temp register
+ code += "crs " + nrmVel + ".xyz," + R + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz\n";
+
+ //use cos as R.w
+ code += "mul " + xAxis + ".xyz," + cos + "," + animationRegisterCache.scaleAndRotateTarget + ".xyz\n";
+ code += "add " + nrmVel + ".xyz," + nrmVel + ".xyz," + xAxis + ".xyz\n";
+ code += "dp3 " + xAxis + ".w," + R + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz\n";
+ code += "neg " + nrmVel + ".w," + xAxis + ".w\n";
+
+ code += "crs " + R + ".xyz," + nrmVel + ".xyz," + R_rev + ".xyz\n";
+ //code += "mul " + xAxis + ".xyzw," + nrmVel + ".xyzw," +R_rev + ".w\n";
+ code += "mul " + xAxis + ".xyzw," + nrmVel + ".xyzw," + cos + "\n";
+ code += "add " + R + ".xyz," + R + ".xyz," + xAxis + ".xyz\n";
+ code += "mul " + xAxis + ".xyz," + nrmVel + ".w," + R_rev + ".xyz\n";
+
+ code += "add " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + R + ".xyz," + xAxis + ".xyz\n";
+
+ for (i = 0; i < len; i++) {
+ //just repeat the calculate above
+ //because of the limited registers, no need to optimise
+ code += "mov " + xAxis + ".x," + animationRegisterCache.vertexOneConst + "\n";
+ code += "mov " + xAxis + ".yz," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "nrm " + nrmVel + ".xyz," + animationRegisterCache.velocityTarget + ".xyz\n";
+ code += "dp3 " + cos2 + "," + nrmVel + ".xyz," + xAxis + ".xyz\n";
+ code += "crs " + nrmVel + ".xyz," + xAxis + ".xyz," + nrmVel + ".xyz\n";
+ code += "nrm " + nrmVel + ".xyz," + nrmVel + ".xyz\n";
+ code += "dp3 " + R + ".x," + nrmVel + ".xyz," + nrmVel + ".xyz\n";
+ code += "sge " + R + ".x," + animationRegisterCache.vertexZeroConst + "," + R + ".x\n";
+ code += "add " + nrmVel + ".z," + R + ".x," + nrmVel + ".z\n";
+ code += "add " + tempSingle + "," + cos2 + "," + animationRegisterCache.vertexOneConst + "\n";
+ code += "div " + tempSingle + "," + tempSingle + "," + animationRegisterCache.vertexTwoConst + "\n";
+ code += "sqt " + cos + "," + tempSingle + "\n";
+ code += "sub " + tempSingle + "," + animationRegisterCache.vertexOneConst + "," + cos2 + "\n";
+ code += "div " + tempSingle + "," + tempSingle + "," + animationRegisterCache.vertexTwoConst + "\n";
+ code += "sqt " + sin + "," + tempSingle + "\n";
+ code += "mul " + R + ".xyz," + sin + "," + nrmVel + ".xyz\n";
+ code += "mul " + R_rev + ".xyz," + sin + "," + nrmVel + ".xyz\n";
+ code += "neg " + R_rev + ".xyz," + R_rev + ".xyz\n";
+ code += "crs " + nrmVel + ".xyz," + R + ".xyz," + animationRegisterCache.rotationRegisters[i] + ".xyz\n";
+ code += "mul " + xAxis + ".xyz," + cos + "," + animationRegisterCache.rotationRegisters[i] + ".xyz\n";
+ code += "add " + nrmVel + ".xyz," + nrmVel + ".xyz," + xAxis + ".xyz\n";
+ code += "dp3 " + xAxis + ".w," + R + ".xyz," + animationRegisterCache.rotationRegisters[i] + ".xyz\n";
+ code += "neg " + nrmVel + ".w," + xAxis + ".w\n";
+ code += "crs " + R + ".xyz," + nrmVel + ".xyz," + R_rev + ".xyz\n";
+ code += "mul " + xAxis + ".xyzw," + nrmVel + ".xyzw," + cos + "\n";
+ code += "add " + R + ".xyz," + R + ".xyz," + xAxis + ".xyz\n";
+ code += "mul " + xAxis + ".xyz," + nrmVel + ".w," + R_rev + ".xyz\n";
+ code += "add " + animationRegisterCache.rotationRegisters[i] + ".xyz," + R + ".xyz," + xAxis + ".xyz\n";
+ }
+
+ }
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):ParticleRotateToHeadingState
+ {
+ return animator.getAnimationState(this);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iProcessAnimationSetting(particleAnimationSet:ParticleAnimationSet)
+ {
+ particleAnimationSet.needVelocity = true;
+ }
+}
+
+export = ParticleRotateToHeadingNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleRotateToPositionNode.js b/lib/animators/nodes/ParticleRotateToPositionNode.js
new file mode 100755
index 000000000..5773a1764
--- /dev/null
+++ b/lib/animators/nodes/ParticleRotateToPositionNode.js
@@ -0,0 +1,182 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+var ParticleRotateToPositionState = require("awayjs-renderergl/lib/animators/states/ParticleRotateToPositionState");
+/**
+ * A particle animation node used to control the rotation of a particle to face to a position
+ */
+var ParticleRotateToPositionNode = (function (_super) {
+ __extends(ParticleRotateToPositionNode, _super);
+ /**
+ * Creates a new ParticleRotateToPositionNode
+ */
+ function ParticleRotateToPositionNode(mode /*uint*/, position) {
+ if (position === void 0) { position = null; }
+ _super.call(this, "ParticleRotateToPosition", mode, 3, 3);
+ this._pStateClass = ParticleRotateToPositionState;
+ this._iPosition = position || new Vector3D();
+ }
+ /**
+ * @inheritDoc
+ */
+ ParticleRotateToPositionNode.prototype.getAGALVertexCode = function (shaderObject, animationRegisterCache) {
+ var positionAttribute = (this._pMode == ParticlePropertiesMode.GLOBAL) ? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleRotateToPositionState.POSITION_INDEX, positionAttribute.index);
+ var code = "";
+ var len = animationRegisterCache.rotationRegisters.length;
+ var i /*int*/;
+ if (animationRegisterCache.hasBillboard) {
+ var temp1 = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp1, 1);
+ var temp2 = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp2, 1);
+ var temp3 = animationRegisterCache.getFreeVertexVectorTemp();
+ var rotationMatrixRegister = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleRotateToPositionState.MATRIX_INDEX, rotationMatrixRegister.index);
+ animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.removeVertexTempUsage(temp1);
+ animationRegisterCache.removeVertexTempUsage(temp2);
+ //process the position
+ code += "sub " + temp1 + ".xyz," + positionAttribute + ".xyz," + animationRegisterCache.positionTarget + ".xyz\n";
+ code += "m33 " + temp1 + ".xyz," + temp1 + ".xyz," + rotationMatrixRegister + "\n";
+ code += "mov " + temp3 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp3 + ".xy," + temp1 + ".xy\n";
+ code += "nrm " + temp3 + ".xyz," + temp3 + ".xyz\n";
+ //temp3.x=cos,temp3.y=sin
+ //only process z axis
+ code += "mov " + temp2 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp2 + ".x," + temp3 + ".y\n";
+ code += "mov " + temp2 + ".y," + temp3 + ".x\n";
+ code += "mov " + temp1 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp1 + ".x," + temp3 + ".x\n";
+ code += "neg " + temp1 + ".y," + temp3 + ".y\n";
+ code += "mov " + temp3 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp3 + ".z," + animationRegisterCache.vertexOneConst + "\n";
+ code += "m33 " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz," + temp1 + "\n";
+ for (i = 0; i < len; i++)
+ code += "m33 " + animationRegisterCache.rotationRegisters[i] + ".xyz," + animationRegisterCache.rotationRegisters[i] + "," + temp1 + "\n";
+ }
+ else {
+ var nrmDirection = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(nrmDirection, 1);
+ var temp = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp, 1);
+ var cos = new ShaderRegisterElement(temp.regName, temp.index, 0);
+ var sin = new ShaderRegisterElement(temp.regName, temp.index, 1);
+ var o_temp = new ShaderRegisterElement(temp.regName, temp.index, 2);
+ var tempSingle = new ShaderRegisterElement(temp.regName, temp.index, 3);
+ var R = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(R, 1);
+ animationRegisterCache.removeVertexTempUsage(nrmDirection);
+ animationRegisterCache.removeVertexTempUsage(temp);
+ animationRegisterCache.removeVertexTempUsage(R);
+ code += "sub " + nrmDirection + ".xyz," + positionAttribute + ".xyz," + animationRegisterCache.positionTarget + ".xyz\n";
+ code += "nrm " + nrmDirection + ".xyz," + nrmDirection + ".xyz\n";
+ code += "mov " + sin + "," + nrmDirection + ".y\n";
+ code += "mul " + cos + "," + sin + "," + sin + "\n";
+ code += "sub " + cos + "," + animationRegisterCache.vertexOneConst + "," + cos + "\n";
+ code += "sqt " + cos + "," + cos + "\n";
+ code += "mul " + R + ".x," + cos + "," + animationRegisterCache.scaleAndRotateTarget + ".y\n";
+ code += "mul " + R + ".y," + sin + "," + animationRegisterCache.scaleAndRotateTarget + ".z\n";
+ code += "mul " + R + ".z," + sin + "," + animationRegisterCache.scaleAndRotateTarget + ".y\n";
+ code += "mul " + R + ".w," + cos + "," + animationRegisterCache.scaleAndRotateTarget + ".z\n";
+ code += "sub " + animationRegisterCache.scaleAndRotateTarget + ".y," + R + ".x," + R + ".y\n";
+ code += "add " + animationRegisterCache.scaleAndRotateTarget + ".z," + R + ".z," + R + ".w\n";
+ code += "abs " + R + ".y," + nrmDirection + ".y\n";
+ code += "sge " + R + ".z," + R + ".y," + animationRegisterCache.vertexOneConst + "\n";
+ code += "mul " + R + ".x," + R + ".y," + nrmDirection + ".y\n";
+ //judgu if nrmDirection=(0,1,0);
+ code += "mov " + nrmDirection + ".y," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "dp3 " + sin + "," + nrmDirection + ".xyz," + nrmDirection + ".xyz\n";
+ code += "sge " + tempSingle + "," + animationRegisterCache.vertexZeroConst + "," + sin + "\n";
+ code += "mov " + nrmDirection + ".y," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "nrm " + nrmDirection + ".xyz," + nrmDirection + ".xyz\n";
+ code += "sub " + sin + "," + animationRegisterCache.vertexOneConst + "," + tempSingle + "\n";
+ code += "mul " + sin + "," + sin + "," + nrmDirection + ".x\n";
+ code += "mov " + cos + "," + nrmDirection + ".z\n";
+ code += "neg " + cos + "," + cos + "\n";
+ code += "sub " + o_temp + "," + animationRegisterCache.vertexOneConst + "," + cos + "\n";
+ code += "mul " + o_temp + "," + R + ".x," + tempSingle + "\n";
+ code += "add " + cos + "," + cos + "," + o_temp + "\n";
+ code += "mul " + R + ".x," + cos + "," + animationRegisterCache.scaleAndRotateTarget + ".x\n";
+ code += "mul " + R + ".y," + sin + "," + animationRegisterCache.scaleAndRotateTarget + ".z\n";
+ code += "mul " + R + ".z," + sin + "," + animationRegisterCache.scaleAndRotateTarget + ".x\n";
+ code += "mul " + R + ".w," + cos + "," + animationRegisterCache.scaleAndRotateTarget + ".z\n";
+ code += "sub " + animationRegisterCache.scaleAndRotateTarget + ".x," + R + ".x," + R + ".y\n";
+ code += "add " + animationRegisterCache.scaleAndRotateTarget + ".z," + R + ".z," + R + ".w\n";
+ for (i = 0; i < len; i++) {
+ //just repeat the calculate above
+ //because of the limited registers, no need to optimise
+ code += "sub " + nrmDirection + ".xyz," + positionAttribute + ".xyz," + animationRegisterCache.positionTarget + ".xyz\n";
+ code += "nrm " + nrmDirection + ".xyz," + nrmDirection + ".xyz\n";
+ code += "mov " + sin + "," + nrmDirection + ".y\n";
+ code += "mul " + cos + "," + sin + "," + sin + "\n";
+ code += "sub " + cos + "," + animationRegisterCache.vertexOneConst + "," + cos + "\n";
+ code += "sqt " + cos + "," + cos + "\n";
+ code += "mul " + R + ".x," + cos + "," + animationRegisterCache.rotationRegisters[i] + ".y\n";
+ code += "mul " + R + ".y," + sin + "," + animationRegisterCache.rotationRegisters[i] + ".z\n";
+ code += "mul " + R + ".z," + sin + "," + animationRegisterCache.rotationRegisters[i] + ".y\n";
+ code += "mul " + R + ".w," + cos + "," + animationRegisterCache.rotationRegisters[i] + ".z\n";
+ code += "sub " + animationRegisterCache.rotationRegisters[i] + ".y," + R + ".x," + R + ".y\n";
+ code += "add " + animationRegisterCache.rotationRegisters[i] + ".z," + R + ".z," + R + ".w\n";
+ code += "abs " + R + ".y," + nrmDirection + ".y\n";
+ code += "sge " + R + ".z," + R + ".y," + animationRegisterCache.vertexOneConst + "\n";
+ code += "mul " + R + ".x," + R + ".y," + nrmDirection + ".y\n";
+ code += "mov " + nrmDirection + ".y," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "dp3 " + sin + "," + nrmDirection + ".xyz," + nrmDirection + ".xyz\n";
+ code += "sge " + tempSingle + "," + animationRegisterCache.vertexZeroConst + "," + sin + "\n";
+ code += "mov " + nrmDirection + ".y," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "nrm " + nrmDirection + ".xyz," + nrmDirection + ".xyz\n";
+ code += "sub " + sin + "," + animationRegisterCache.vertexOneConst + "," + tempSingle + "\n";
+ code += "mul " + sin + "," + sin + "," + nrmDirection + ".x\n";
+ code += "mov " + cos + "," + nrmDirection + ".z\n";
+ code += "neg " + cos + "," + cos + "\n";
+ code += "sub " + o_temp + "," + animationRegisterCache.vertexOneConst + "," + cos + "\n";
+ code += "mul " + o_temp + "," + R + ".x," + tempSingle + "\n";
+ code += "add " + cos + "," + cos + "," + o_temp + "\n";
+ code += "mul " + R + ".x," + cos + "," + animationRegisterCache.rotationRegisters[i] + ".x\n";
+ code += "mul " + R + ".y," + sin + "," + animationRegisterCache.rotationRegisters[i] + ".z\n";
+ code += "mul " + R + ".z," + sin + "," + animationRegisterCache.rotationRegisters[i] + ".x\n";
+ code += "mul " + R + ".w," + cos + "," + animationRegisterCache.rotationRegisters[i] + ".z\n";
+ code += "sub " + animationRegisterCache.rotationRegisters[i] + ".x," + R + ".x," + R + ".y\n";
+ code += "add " + animationRegisterCache.rotationRegisters[i] + ".z," + R + ".z," + R + ".w\n";
+ }
+ }
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleRotateToPositionNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleRotateToPositionNode.prototype._iGeneratePropertyOfOneParticle = function (param) {
+ var offset = param[ParticleRotateToPositionNode.POSITION_VECTOR3D];
+ if (!offset)
+ throw (new Error("there is no " + ParticleRotateToPositionNode.POSITION_VECTOR3D + " in param!"));
+ this._pOneData[0] = offset.x;
+ this._pOneData[1] = offset.y;
+ this._pOneData[2] = offset.z;
+ };
+ /**
+ * Reference for the position the particle will rotate to face for a single particle (when in local property mode).
+ * Expects a Vector3D
object representing the position that the particle must face.
+ */
+ ParticleRotateToPositionNode.POSITION_VECTOR3D = "RotateToPositionVector3D";
+ return ParticleRotateToPositionNode;
+})(ParticleNodeBase);
+module.exports = ParticleRotateToPositionNode;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/nodes/particlerotatetopositionnode.ts"],"names":["ParticleRotateToPositionNode","ParticleRotateToPositionNode.constructor","ParticleRotateToPositionNode.getAGALVertexCode","ParticleRotateToPositionNode.getAnimationState","ParticleRotateToPositionNode._iGeneratePropertyOfOneParticle"],"mappings":"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","file":"animators/nodes/ParticleRotateToPositionNode.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\n\nimport ParticleProperties\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleProperties\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleNodeBase\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleNodeBase\");\nimport ParticleRotateToPositionState\t= require(\"awayjs-renderergl/lib/animators/states/ParticleRotateToPositionState\");\n\n/**\n * A particle animation node used to control the rotation of a particle to face to a position\n */\nclass ParticleRotateToPositionNode extends ParticleNodeBase\n{\n\t/** @private */\n\tpublic _iPosition:Vector3D;\n\n\t/**\n\t * Reference for the position the particle will rotate to face for a single particle (when in local property mode).\n\t * Expects a <code>Vector3D</code> object representing the position that the particle must face.\n\t */\n\tpublic static POSITION_VECTOR3D:string = \"RotateToPositionVector3D\";\n\n\t/**\n\t * Creates a new <code>ParticleRotateToPositionNode</code>\n\t */\n\tconstructor(mode:number /*uint*/, position:Vector3D = null)\n\t{\n\t\tsuper(\"ParticleRotateToPosition\", mode, 3, 3);\n\n\t\tthis._pStateClass = ParticleRotateToPositionState;\n\n\t\tthis._iPosition = position || new Vector3D();\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string\n\t{\n\t\tvar positionAttribute:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();\n\t\tanimationRegisterCache.setRegisterIndex(this, ParticleRotateToPositionState.POSITION_INDEX, positionAttribute.index);\n\n\t\tvar code:string = \"\";\n\t\tvar len:number /*int*/ = animationRegisterCache.rotationRegisters.length;\n\t\tvar i:number /*int*/;\n\t\tif (animationRegisterCache.hasBillboard) {\n\t\t\tvar temp1:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\t\tanimationRegisterCache.addVertexTempUsages(temp1, 1);\n\t\t\tvar temp2:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\t\tanimationRegisterCache.addVertexTempUsages(temp2, 1);\n\t\t\tvar temp3:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\n\t\t\tvar rotationMatrixRegister:ShaderRegisterElement = animationRegisterCache.getFreeVertexConstant();\n\t\t\tanimationRegisterCache.setRegisterIndex(this, ParticleRotateToPositionState.MATRIX_INDEX, rotationMatrixRegister.index);\n\t\t\tanimationRegisterCache.getFreeVertexConstant();\n\t\t\tanimationRegisterCache.getFreeVertexConstant();\n\t\t\tanimationRegisterCache.getFreeVertexConstant();\n\n\t\t\tanimationRegisterCache.removeVertexTempUsage(temp1);\n\t\t\tanimationRegisterCache.removeVertexTempUsage(temp2);\n\n\t\t\t//process the position\n\t\t\tcode += \"sub \" + temp1 + \".xyz,\" + positionAttribute + \".xyz,\" + animationRegisterCache.positionTarget + \".xyz\\n\";\n\t\t\tcode += \"m33 \" + temp1 + \".xyz,\" + temp1 + \".xyz,\" + rotationMatrixRegister + \"\\n\";\n\n\t\t\tcode += \"mov \" + temp3 + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"mov \" + temp3 + \".xy,\" + temp1 + \".xy\\n\";\n\t\t\tcode += \"nrm \" + temp3 + \".xyz,\" + temp3 + \".xyz\\n\";\n\n\t\t\t//temp3.x=cos,temp3.y=sin\n\t\t\t//only process z axis\n\t\t\tcode += \"mov \" + temp2 + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"mov \" + temp2 + \".x,\" + temp3 + \".y\\n\";\n\t\t\tcode += \"mov \" + temp2 + \".y,\" + temp3 + \".x\\n\";\n\t\t\tcode += \"mov \" + temp1 + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"mov \" + temp1 + \".x,\" + temp3 + \".x\\n\";\n\t\t\tcode += \"neg \" + temp1 + \".y,\" + temp3 + \".y\\n\";\n\t\t\tcode += \"mov \" + temp3 + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"mov \" + temp3 + \".z,\" + animationRegisterCache.vertexOneConst + \"\\n\";\n\t\t\tcode += \"m33 \" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + temp1 + \"\\n\";\n\t\t\tfor (i = 0; i < len; i++)\n\t\t\t\tcode += \"m33 \" + animationRegisterCache.rotationRegisters[i] + \".xyz,\" + animationRegisterCache.rotationRegisters[i] + \",\" + temp1 + \"\\n\";\n\t\t} else {\n\t\t\tvar nrmDirection:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\t\tanimationRegisterCache.addVertexTempUsages(nrmDirection, 1);\n\n\t\t\tvar temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\t\tanimationRegisterCache.addVertexTempUsages(temp, 1);\n\t\t\tvar cos:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 0);\n\t\t\tvar sin:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 1);\n\t\t\tvar o_temp:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 2);\n\t\t\tvar tempSingle:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 3);\n\n\t\t\tvar R:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\t\tanimationRegisterCache.addVertexTempUsages(R, 1);\n\n\t\t\tanimationRegisterCache.removeVertexTempUsage(nrmDirection);\n\t\t\tanimationRegisterCache.removeVertexTempUsage(temp);\n\t\t\tanimationRegisterCache.removeVertexTempUsage(R);\n\n\t\t\tcode += \"sub \" + nrmDirection + \".xyz,\" + positionAttribute + \".xyz,\" + animationRegisterCache.positionTarget + \".xyz\\n\";\n\t\t\tcode += \"nrm \" + nrmDirection + \".xyz,\" + nrmDirection + \".xyz\\n\";\n\n\t\t\tcode += \"mov \" + sin + \",\" + nrmDirection + \".y\\n\";\n\t\t\tcode += \"mul \" + cos + \",\" + sin + \",\" + sin + \"\\n\";\n\t\t\tcode += \"sub \" + cos + \",\" + animationRegisterCache.vertexOneConst + \",\" + cos + \"\\n\";\n\t\t\tcode += \"sqt \" + cos + \",\" + cos + \"\\n\";\n\n\t\t\tcode += \"mul \" + R + \".x,\" + cos + \",\" + animationRegisterCache.scaleAndRotateTarget + \".y\\n\";\n\t\t\tcode += \"mul \" + R + \".y,\" + sin + \",\" + animationRegisterCache.scaleAndRotateTarget + \".z\\n\";\n\t\t\tcode += \"mul \" + R + \".z,\" + sin + \",\" + animationRegisterCache.scaleAndRotateTarget + \".y\\n\";\n\t\t\tcode += \"mul \" + R + \".w,\" + cos + \",\" + animationRegisterCache.scaleAndRotateTarget + \".z\\n\";\n\n\t\t\tcode += \"sub \" + animationRegisterCache.scaleAndRotateTarget + \".y,\" + R + \".x,\" + R + \".y\\n\";\n\t\t\tcode += \"add \" + animationRegisterCache.scaleAndRotateTarget + \".z,\" + R + \".z,\" + R + \".w\\n\";\n\n\t\t\tcode += \"abs \" + R + \".y,\" + nrmDirection + \".y\\n\";\n\t\t\tcode += \"sge \" + R + \".z,\" + R + \".y,\" + animationRegisterCache.vertexOneConst + \"\\n\";\n\t\t\tcode += \"mul \" + R + \".x,\" + R + \".y,\" + nrmDirection + \".y\\n\";\n\n\t\t\t//judgu if nrmDirection=(0,1,0);\n\t\t\tcode += \"mov \" + nrmDirection + \".y,\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"dp3 \" + sin + \",\" + nrmDirection + \".xyz,\" + nrmDirection + \".xyz\\n\";\n\t\t\tcode += \"sge \" + tempSingle + \",\" + animationRegisterCache.vertexZeroConst + \",\" + sin + \"\\n\";\n\n\t\t\tcode += \"mov \" + nrmDirection + \".y,\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"nrm \" + nrmDirection + \".xyz,\" + nrmDirection + \".xyz\\n\";\n\n\t\t\tcode += \"sub \" + sin + \",\" + animationRegisterCache.vertexOneConst + \",\" + tempSingle + \"\\n\";\n\t\t\tcode += \"mul \" + sin + \",\" + sin + \",\" + nrmDirection + \".x\\n\";\n\n\t\t\tcode += \"mov \" + cos + \",\" + nrmDirection + \".z\\n\";\n\t\t\tcode += \"neg \" + cos + \",\" + cos + \"\\n\";\n\t\t\tcode += \"sub \" + o_temp + \",\" + animationRegisterCache.vertexOneConst + \",\" + cos + \"\\n\";\n\t\t\tcode += \"mul \" + o_temp + \",\" + R + \".x,\" + tempSingle + \"\\n\";\n\t\t\tcode += \"add \" + cos + \",\" + cos + \",\" + o_temp + \"\\n\";\n\n\t\t\tcode += \"mul \" + R + \".x,\" + cos + \",\" + animationRegisterCache.scaleAndRotateTarget + \".x\\n\";\n\t\t\tcode += \"mul \" + R + \".y,\" + sin + \",\" + animationRegisterCache.scaleAndRotateTarget + \".z\\n\";\n\t\t\tcode += \"mul \" + R + \".z,\" + sin + \",\" + animationRegisterCache.scaleAndRotateTarget + \".x\\n\";\n\t\t\tcode += \"mul \" + R + \".w,\" + cos + \",\" + animationRegisterCache.scaleAndRotateTarget + \".z\\n\";\n\n\t\t\tcode += \"sub \" + animationRegisterCache.scaleAndRotateTarget + \".x,\" + R + \".x,\" + R + \".y\\n\";\n\t\t\tcode += \"add \" + animationRegisterCache.scaleAndRotateTarget + \".z,\" + R + \".z,\" + R + \".w\\n\";\n\n\t\t\tfor (i = 0; i < len; i++) {\n\t\t\t\t//just repeat the calculate above\n\t\t\t\t//because of the limited registers, no need to optimise\n\t\t\t\tcode += \"sub \" + nrmDirection + \".xyz,\" + positionAttribute + \".xyz,\" + animationRegisterCache.positionTarget + \".xyz\\n\";\n\t\t\t\tcode += \"nrm \" + nrmDirection + \".xyz,\" + nrmDirection + \".xyz\\n\";\n\t\t\t\tcode += \"mov \" + sin + \",\" + nrmDirection + \".y\\n\";\n\t\t\t\tcode += \"mul \" + cos + \",\" + sin + \",\" + sin + \"\\n\";\n\t\t\t\tcode += \"sub \" + cos + \",\" + animationRegisterCache.vertexOneConst + \",\" + cos + \"\\n\";\n\t\t\t\tcode += \"sqt \" + cos + \",\" + cos + \"\\n\";\n\t\t\t\tcode += \"mul \" + R + \".x,\" + cos + \",\" + animationRegisterCache.rotationRegisters[i] + \".y\\n\";\n\t\t\t\tcode += \"mul \" + R + \".y,\" + sin + \",\" + animationRegisterCache.rotationRegisters[i] + \".z\\n\";\n\t\t\t\tcode += \"mul \" + R + \".z,\" + sin + \",\" + animationRegisterCache.rotationRegisters[i] + \".y\\n\";\n\t\t\t\tcode += \"mul \" + R + \".w,\" + cos + \",\" + animationRegisterCache.rotationRegisters[i] + \".z\\n\";\n\t\t\t\tcode += \"sub \" + animationRegisterCache.rotationRegisters[i] + \".y,\" + R + \".x,\" + R + \".y\\n\";\n\t\t\t\tcode += \"add \" + animationRegisterCache.rotationRegisters[i] + \".z,\" + R + \".z,\" + R + \".w\\n\";\n\t\t\t\tcode += \"abs \" + R + \".y,\" + nrmDirection + \".y\\n\";\n\t\t\t\tcode += \"sge \" + R + \".z,\" + R + \".y,\" + animationRegisterCache.vertexOneConst + \"\\n\";\n\t\t\t\tcode += \"mul \" + R + \".x,\" + R + \".y,\" + nrmDirection + \".y\\n\";\n\t\t\t\tcode += \"mov \" + nrmDirection + \".y,\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\t\tcode += \"dp3 \" + sin + \",\" + nrmDirection + \".xyz,\" + nrmDirection + \".xyz\\n\";\n\t\t\t\tcode += \"sge \" + tempSingle + \",\" + animationRegisterCache.vertexZeroConst + \",\" + sin + \"\\n\";\n\t\t\t\tcode += \"mov \" + nrmDirection + \".y,\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\t\tcode += \"nrm \" + nrmDirection + \".xyz,\" + nrmDirection + \".xyz\\n\";\n\t\t\t\tcode += \"sub \" + sin + \",\" + animationRegisterCache.vertexOneConst + \",\" + tempSingle + \"\\n\";\n\t\t\t\tcode += \"mul \" + sin + \",\" + sin + \",\" + nrmDirection + \".x\\n\";\n\t\t\t\tcode += \"mov \" + cos + \",\" + nrmDirection + \".z\\n\";\n\t\t\t\tcode += \"neg \" + cos + \",\" + cos + \"\\n\";\n\t\t\t\tcode += \"sub \" + o_temp + \",\" + animationRegisterCache.vertexOneConst + \",\" + cos + \"\\n\";\n\t\t\t\tcode += \"mul \" + o_temp + \",\" + R + \".x,\" + tempSingle + \"\\n\";\n\t\t\t\tcode += \"add \" + cos + \",\" + cos + \",\" + o_temp + \"\\n\";\n\t\t\t\tcode += \"mul \" + R + \".x,\" + cos + \",\" + animationRegisterCache.rotationRegisters[i] + \".x\\n\";\n\t\t\t\tcode += \"mul \" + R + \".y,\" + sin + \",\" + animationRegisterCache.rotationRegisters[i] + \".z\\n\";\n\t\t\t\tcode += \"mul \" + R + \".z,\" + sin + \",\" + animationRegisterCache.rotationRegisters[i] + \".x\\n\";\n\t\t\t\tcode += \"mul \" + R + \".w,\" + cos + \",\" + animationRegisterCache.rotationRegisters[i] + \".z\\n\";\n\t\t\t\tcode += \"sub \" + animationRegisterCache.rotationRegisters[i] + \".x,\" + R + \".x,\" + R + \".y\\n\";\n\t\t\t\tcode += \"add \" + animationRegisterCache.rotationRegisters[i] + \".z,\" + R + \".z,\" + R + \".w\\n\";\n\t\t\t}\n\t\t}\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAnimationState(animator:AnimatorBase):ParticleRotateToPositionState\n\t{\n\t\treturn <ParticleRotateToPositionState> animator.getAnimationState(this);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _iGeneratePropertyOfOneParticle(param:ParticleProperties)\n\t{\n\t\tvar offset:Vector3D = param[ParticleRotateToPositionNode.POSITION_VECTOR3D];\n\t\tif (!offset)\n\t\t\tthrow(new Error(\"there is no \" + ParticleRotateToPositionNode.POSITION_VECTOR3D + \" in param!\"));\n\n\t\tthis._pOneData[0] = offset.x;\n\t\tthis._pOneData[1] = offset.y;\n\t\tthis._pOneData[2] = offset.z;\n\t}\n}\n\nexport = ParticleRotateToPositionNode;"]}
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleRotateToPositionNode.ts b/lib/animators/nodes/ParticleRotateToPositionNode.ts
new file mode 100644
index 000000000..a897510c8
--- /dev/null
+++ b/lib/animators/nodes/ParticleRotateToPositionNode.ts
@@ -0,0 +1,214 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleRotateToPositionState = require("awayjs-renderergl/lib/animators/states/ParticleRotateToPositionState");
+
+/**
+ * A particle animation node used to control the rotation of a particle to face to a position
+ */
+class ParticleRotateToPositionNode extends ParticleNodeBase
+{
+ /** @private */
+ public _iPosition:Vector3D;
+
+ /**
+ * Reference for the position the particle will rotate to face for a single particle (when in local property mode).
+ * Expects a Vector3D
object representing the position that the particle must face.
+ */
+ public static POSITION_VECTOR3D:string = "RotateToPositionVector3D";
+
+ /**
+ * Creates a new ParticleRotateToPositionNode
+ */
+ constructor(mode:number /*uint*/, position:Vector3D = null)
+ {
+ super("ParticleRotateToPosition", mode, 3, 3);
+
+ this._pStateClass = ParticleRotateToPositionState;
+
+ this._iPosition = position || new Vector3D();
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ var positionAttribute:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleRotateToPositionState.POSITION_INDEX, positionAttribute.index);
+
+ var code:string = "";
+ var len:number /*int*/ = animationRegisterCache.rotationRegisters.length;
+ var i:number /*int*/;
+ if (animationRegisterCache.hasBillboard) {
+ var temp1:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp1, 1);
+ var temp2:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp2, 1);
+ var temp3:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+
+ var rotationMatrixRegister:ShaderRegisterElement = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleRotateToPositionState.MATRIX_INDEX, rotationMatrixRegister.index);
+ animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.getFreeVertexConstant();
+
+ animationRegisterCache.removeVertexTempUsage(temp1);
+ animationRegisterCache.removeVertexTempUsage(temp2);
+
+ //process the position
+ code += "sub " + temp1 + ".xyz," + positionAttribute + ".xyz," + animationRegisterCache.positionTarget + ".xyz\n";
+ code += "m33 " + temp1 + ".xyz," + temp1 + ".xyz," + rotationMatrixRegister + "\n";
+
+ code += "mov " + temp3 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp3 + ".xy," + temp1 + ".xy\n";
+ code += "nrm " + temp3 + ".xyz," + temp3 + ".xyz\n";
+
+ //temp3.x=cos,temp3.y=sin
+ //only process z axis
+ code += "mov " + temp2 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp2 + ".x," + temp3 + ".y\n";
+ code += "mov " + temp2 + ".y," + temp3 + ".x\n";
+ code += "mov " + temp1 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp1 + ".x," + temp3 + ".x\n";
+ code += "neg " + temp1 + ".y," + temp3 + ".y\n";
+ code += "mov " + temp3 + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mov " + temp3 + ".z," + animationRegisterCache.vertexOneConst + "\n";
+ code += "m33 " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz," + temp1 + "\n";
+ for (i = 0; i < len; i++)
+ code += "m33 " + animationRegisterCache.rotationRegisters[i] + ".xyz," + animationRegisterCache.rotationRegisters[i] + "," + temp1 + "\n";
+ } else {
+ var nrmDirection:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(nrmDirection, 1);
+
+ var temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp, 1);
+ var cos:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 0);
+ var sin:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 1);
+ var o_temp:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 2);
+ var tempSingle:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 3);
+
+ var R:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(R, 1);
+
+ animationRegisterCache.removeVertexTempUsage(nrmDirection);
+ animationRegisterCache.removeVertexTempUsage(temp);
+ animationRegisterCache.removeVertexTempUsage(R);
+
+ code += "sub " + nrmDirection + ".xyz," + positionAttribute + ".xyz," + animationRegisterCache.positionTarget + ".xyz\n";
+ code += "nrm " + nrmDirection + ".xyz," + nrmDirection + ".xyz\n";
+
+ code += "mov " + sin + "," + nrmDirection + ".y\n";
+ code += "mul " + cos + "," + sin + "," + sin + "\n";
+ code += "sub " + cos + "," + animationRegisterCache.vertexOneConst + "," + cos + "\n";
+ code += "sqt " + cos + "," + cos + "\n";
+
+ code += "mul " + R + ".x," + cos + "," + animationRegisterCache.scaleAndRotateTarget + ".y\n";
+ code += "mul " + R + ".y," + sin + "," + animationRegisterCache.scaleAndRotateTarget + ".z\n";
+ code += "mul " + R + ".z," + sin + "," + animationRegisterCache.scaleAndRotateTarget + ".y\n";
+ code += "mul " + R + ".w," + cos + "," + animationRegisterCache.scaleAndRotateTarget + ".z\n";
+
+ code += "sub " + animationRegisterCache.scaleAndRotateTarget + ".y," + R + ".x," + R + ".y\n";
+ code += "add " + animationRegisterCache.scaleAndRotateTarget + ".z," + R + ".z," + R + ".w\n";
+
+ code += "abs " + R + ".y," + nrmDirection + ".y\n";
+ code += "sge " + R + ".z," + R + ".y," + animationRegisterCache.vertexOneConst + "\n";
+ code += "mul " + R + ".x," + R + ".y," + nrmDirection + ".y\n";
+
+ //judgu if nrmDirection=(0,1,0);
+ code += "mov " + nrmDirection + ".y," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "dp3 " + sin + "," + nrmDirection + ".xyz," + nrmDirection + ".xyz\n";
+ code += "sge " + tempSingle + "," + animationRegisterCache.vertexZeroConst + "," + sin + "\n";
+
+ code += "mov " + nrmDirection + ".y," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "nrm " + nrmDirection + ".xyz," + nrmDirection + ".xyz\n";
+
+ code += "sub " + sin + "," + animationRegisterCache.vertexOneConst + "," + tempSingle + "\n";
+ code += "mul " + sin + "," + sin + "," + nrmDirection + ".x\n";
+
+ code += "mov " + cos + "," + nrmDirection + ".z\n";
+ code += "neg " + cos + "," + cos + "\n";
+ code += "sub " + o_temp + "," + animationRegisterCache.vertexOneConst + "," + cos + "\n";
+ code += "mul " + o_temp + "," + R + ".x," + tempSingle + "\n";
+ code += "add " + cos + "," + cos + "," + o_temp + "\n";
+
+ code += "mul " + R + ".x," + cos + "," + animationRegisterCache.scaleAndRotateTarget + ".x\n";
+ code += "mul " + R + ".y," + sin + "," + animationRegisterCache.scaleAndRotateTarget + ".z\n";
+ code += "mul " + R + ".z," + sin + "," + animationRegisterCache.scaleAndRotateTarget + ".x\n";
+ code += "mul " + R + ".w," + cos + "," + animationRegisterCache.scaleAndRotateTarget + ".z\n";
+
+ code += "sub " + animationRegisterCache.scaleAndRotateTarget + ".x," + R + ".x," + R + ".y\n";
+ code += "add " + animationRegisterCache.scaleAndRotateTarget + ".z," + R + ".z," + R + ".w\n";
+
+ for (i = 0; i < len; i++) {
+ //just repeat the calculate above
+ //because of the limited registers, no need to optimise
+ code += "sub " + nrmDirection + ".xyz," + positionAttribute + ".xyz," + animationRegisterCache.positionTarget + ".xyz\n";
+ code += "nrm " + nrmDirection + ".xyz," + nrmDirection + ".xyz\n";
+ code += "mov " + sin + "," + nrmDirection + ".y\n";
+ code += "mul " + cos + "," + sin + "," + sin + "\n";
+ code += "sub " + cos + "," + animationRegisterCache.vertexOneConst + "," + cos + "\n";
+ code += "sqt " + cos + "," + cos + "\n";
+ code += "mul " + R + ".x," + cos + "," + animationRegisterCache.rotationRegisters[i] + ".y\n";
+ code += "mul " + R + ".y," + sin + "," + animationRegisterCache.rotationRegisters[i] + ".z\n";
+ code += "mul " + R + ".z," + sin + "," + animationRegisterCache.rotationRegisters[i] + ".y\n";
+ code += "mul " + R + ".w," + cos + "," + animationRegisterCache.rotationRegisters[i] + ".z\n";
+ code += "sub " + animationRegisterCache.rotationRegisters[i] + ".y," + R + ".x," + R + ".y\n";
+ code += "add " + animationRegisterCache.rotationRegisters[i] + ".z," + R + ".z," + R + ".w\n";
+ code += "abs " + R + ".y," + nrmDirection + ".y\n";
+ code += "sge " + R + ".z," + R + ".y," + animationRegisterCache.vertexOneConst + "\n";
+ code += "mul " + R + ".x," + R + ".y," + nrmDirection + ".y\n";
+ code += "mov " + nrmDirection + ".y," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "dp3 " + sin + "," + nrmDirection + ".xyz," + nrmDirection + ".xyz\n";
+ code += "sge " + tempSingle + "," + animationRegisterCache.vertexZeroConst + "," + sin + "\n";
+ code += "mov " + nrmDirection + ".y," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "nrm " + nrmDirection + ".xyz," + nrmDirection + ".xyz\n";
+ code += "sub " + sin + "," + animationRegisterCache.vertexOneConst + "," + tempSingle + "\n";
+ code += "mul " + sin + "," + sin + "," + nrmDirection + ".x\n";
+ code += "mov " + cos + "," + nrmDirection + ".z\n";
+ code += "neg " + cos + "," + cos + "\n";
+ code += "sub " + o_temp + "," + animationRegisterCache.vertexOneConst + "," + cos + "\n";
+ code += "mul " + o_temp + "," + R + ".x," + tempSingle + "\n";
+ code += "add " + cos + "," + cos + "," + o_temp + "\n";
+ code += "mul " + R + ".x," + cos + "," + animationRegisterCache.rotationRegisters[i] + ".x\n";
+ code += "mul " + R + ".y," + sin + "," + animationRegisterCache.rotationRegisters[i] + ".z\n";
+ code += "mul " + R + ".z," + sin + "," + animationRegisterCache.rotationRegisters[i] + ".x\n";
+ code += "mul " + R + ".w," + cos + "," + animationRegisterCache.rotationRegisters[i] + ".z\n";
+ code += "sub " + animationRegisterCache.rotationRegisters[i] + ".x," + R + ".x," + R + ".y\n";
+ code += "add " + animationRegisterCache.rotationRegisters[i] + ".z," + R + ".z," + R + ".w\n";
+ }
+ }
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):ParticleRotateToPositionState
+ {
+ return animator.getAnimationState(this);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iGeneratePropertyOfOneParticle(param:ParticleProperties)
+ {
+ var offset:Vector3D = param[ParticleRotateToPositionNode.POSITION_VECTOR3D];
+ if (!offset)
+ throw(new Error("there is no " + ParticleRotateToPositionNode.POSITION_VECTOR3D + " in param!"));
+
+ this._pOneData[0] = offset.x;
+ this._pOneData[1] = offset.y;
+ this._pOneData[2] = offset.z;
+ }
+}
+
+export = ParticleRotateToPositionNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleRotationalVelocityNode.js b/lib/animators/nodes/ParticleRotationalVelocityNode.js
new file mode 100755
index 000000000..12e3f615d
--- /dev/null
+++ b/lib/animators/nodes/ParticleRotationalVelocityNode.js
@@ -0,0 +1,127 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+var ParticleRotationalVelocityState = require("awayjs-renderergl/lib/animators/states/ParticleRotationalVelocityState");
+/**
+ * A particle animation node used to set the starting rotational velocity of a particle.
+ */
+var ParticleRotationalVelocityNode = (function (_super) {
+ __extends(ParticleRotationalVelocityNode, _super);
+ /**
+ * Creates a new ParticleRotationalVelocityNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ */
+ function ParticleRotationalVelocityNode(mode /*uint*/, rotationalVelocity) {
+ if (rotationalVelocity === void 0) { rotationalVelocity = null; }
+ _super.call(this, "ParticleRotationalVelocity", mode, 4);
+ this._pStateClass = ParticleRotationalVelocityState;
+ this._iRotationalVelocity = rotationalVelocity || new Vector3D();
+ }
+ /**
+ * @inheritDoc
+ */
+ ParticleRotationalVelocityNode.prototype.getAGALVertexCode = function (shaderObject, animationRegisterCache) {
+ var rotationRegister = (this._pMode == ParticlePropertiesMode.GLOBAL) ? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleRotationalVelocityState.ROTATIONALVELOCITY_INDEX, rotationRegister.index);
+ var nrmVel = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(nrmVel, 1);
+ var xAxis = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(xAxis, 1);
+ var temp = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp, 1);
+ var Rtemp = new ShaderRegisterElement(temp.regName, temp.index);
+ var R_rev = animationRegisterCache.getFreeVertexVectorTemp();
+ R_rev = new ShaderRegisterElement(R_rev.regName, R_rev.index);
+ var cos = new ShaderRegisterElement(Rtemp.regName, Rtemp.index, 3);
+ var sin = new ShaderRegisterElement(R_rev.regName, R_rev.index, 3);
+ animationRegisterCache.removeVertexTempUsage(nrmVel);
+ animationRegisterCache.removeVertexTempUsage(xAxis);
+ animationRegisterCache.removeVertexTempUsage(temp);
+ var code = "";
+ code += "mov " + nrmVel + ".xyz," + rotationRegister + ".xyz\n";
+ code += "mov " + nrmVel + ".w," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mul " + cos + "," + animationRegisterCache.vertexTime + "," + rotationRegister + ".w\n";
+ code += "sin " + sin + "," + cos + "\n";
+ code += "cos " + cos + "," + cos + "\n";
+ code += "mul " + Rtemp + ".xyz," + sin + "," + nrmVel + ".xyz\n";
+ code += "mul " + R_rev + ".xyz," + sin + "," + nrmVel + ".xyz\n";
+ code += "neg " + R_rev + ".xyz," + R_rev + ".xyz\n";
+ //nrmVel and xAxis are used as temp register
+ code += "crs " + nrmVel + ".xyz," + Rtemp + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz\n";
+ code += "mul " + xAxis + ".xyz," + cos + "," + animationRegisterCache.scaleAndRotateTarget + ".xyz\n";
+ code += "add " + nrmVel + ".xyz," + nrmVel + ".xyz," + xAxis + ".xyz\n";
+ code += "dp3 " + xAxis + ".w," + Rtemp + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz\n";
+ code += "neg " + nrmVel + ".w," + xAxis + ".w\n";
+ code += "crs " + Rtemp + ".xyz," + nrmVel + ".xyz," + R_rev + ".xyz\n";
+ //use cos as R_rev.w
+ code += "mul " + xAxis + ".xyzw," + nrmVel + ".xyzw," + cos + "\n";
+ code += "add " + Rtemp + ".xyz," + Rtemp + ".xyz," + xAxis + ".xyz\n";
+ code += "mul " + xAxis + ".xyz," + nrmVel + ".w," + R_rev + ".xyz\n";
+ code += "add " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + Rtemp + ".xyz," + xAxis + ".xyz\n";
+ var len = animationRegisterCache.rotationRegisters.length;
+ for (var i = 0; i < len; i++) {
+ code += "mov " + nrmVel + ".xyz," + rotationRegister + ".xyz\n";
+ code += "mov " + nrmVel + ".w," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mul " + cos + "," + animationRegisterCache.vertexTime + "," + rotationRegister + ".w\n";
+ code += "sin " + sin + "," + cos + "\n";
+ code += "cos " + cos + "," + cos + "\n";
+ code += "mul " + Rtemp + ".xyz," + sin + "," + nrmVel + ".xyz\n";
+ code += "mul " + R_rev + ".xyz," + sin + "," + nrmVel + ".xyz\n";
+ code += "neg " + R_rev + ".xyz," + R_rev + ".xyz\n";
+ code += "crs " + nrmVel + ".xyz," + Rtemp + ".xyz," + animationRegisterCache.rotationRegisters[i] + ".xyz\n";
+ code += "mul " + xAxis + ".xyz," + cos + "," + animationRegisterCache.rotationRegisters[i] + "\n";
+ code += "add " + nrmVel + ".xyz," + nrmVel + ".xyz," + xAxis + ".xyz\n";
+ code += "dp3 " + xAxis + ".w," + Rtemp + ".xyz," + animationRegisterCache.rotationRegisters[i] + "\n";
+ code += "neg " + nrmVel + ".w," + xAxis + ".w\n";
+ code += "crs " + Rtemp + ".xyz," + nrmVel + ".xyz," + R_rev + ".xyz\n";
+ code += "mul " + xAxis + ".xyzw," + nrmVel + ".xyzw," + cos + "\n";
+ code += "add " + Rtemp + ".xyz," + Rtemp + ".xyz," + xAxis + ".xyz\n";
+ code += "mul " + xAxis + ".xyz," + nrmVel + ".w," + R_rev + ".xyz\n";
+ code += "add " + animationRegisterCache.rotationRegisters[i] + "," + Rtemp + ".xyz," + xAxis + ".xyz\n";
+ }
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleRotationalVelocityNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleRotationalVelocityNode.prototype._iGeneratePropertyOfOneParticle = function (param) {
+ //(Vector3d.x,Vector3d.y,Vector3d.z) is rotation axis,Vector3d.w is cycle duration
+ var rotate = param[ParticleRotationalVelocityNode.ROTATIONALVELOCITY_VECTOR3D];
+ if (!rotate)
+ throw (new Error("there is no " + ParticleRotationalVelocityNode.ROTATIONALVELOCITY_VECTOR3D + " in param!"));
+ if (rotate.length <= 0)
+ rotate.z = 1; //set the default direction
+ else
+ rotate.normalize();
+ this._pOneData[0] = rotate.x;
+ this._pOneData[1] = rotate.y;
+ this._pOneData[2] = rotate.z;
+ if (rotate.w <= 0)
+ throw (new Error("the cycle duration must greater than zero"));
+ // it's used as angle/2 in agal
+ this._pOneData[3] = Math.PI / rotate.w;
+ };
+ /**
+ * Reference for rotational velocity node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
object representing the rotational velocity around an axis of the particle.
+ */
+ ParticleRotationalVelocityNode.ROTATIONALVELOCITY_VECTOR3D = "RotationalVelocityVector3D";
+ return ParticleRotationalVelocityNode;
+})(ParticleNodeBase);
+module.exports = ParticleRotationalVelocityNode;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/nodes/particlerotationalvelocitynode.ts"],"names":["ParticleRotationalVelocityNode","ParticleRotationalVelocityNode.constructor","ParticleRotationalVelocityNode.getAGALVertexCode","ParticleRotationalVelocityNode.getAnimationState","ParticleRotationalVelocityNode._iGeneratePropertyOfOneParticle"],"mappings":"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","file":"animators/nodes/ParticleRotationalVelocityNode.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\n\nimport ParticleProperties\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleProperties\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleNodeBase\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleNodeBase\");\nimport ParticleRotationalVelocityState\t= require(\"awayjs-renderergl/lib/animators/states/ParticleRotationalVelocityState\");\n\n/**\n * A particle animation node used to set the starting rotational velocity of a particle.\n */\nclass ParticleRotationalVelocityNode extends ParticleNodeBase\n{\n\t/** @private */\n\tpublic _iRotationalVelocity:Vector3D;\n\n\t/**\n\t * Reference for rotational velocity node properties on a single particle (when in local property mode).\n\t * Expects a <code>Vector3D</code> object representing the rotational velocity around an axis of the particle.\n\t */\n\tpublic static ROTATIONALVELOCITY_VECTOR3D:string = \"RotationalVelocityVector3D\";\n\n\t/**\n\t * Creates a new <code>ParticleRotationalVelocityNode</code>\n\t *\n\t * @param               mode            Defines whether the mode of operation acts on local properties of a particle or global properties of the node.\n\t */\n\tconstructor(mode:number /*uint*/, rotationalVelocity:Vector3D = null)\n\t{\n\t\tsuper(\"ParticleRotationalVelocity\", mode, 4);\n\n\t\tthis._pStateClass = ParticleRotationalVelocityState;\n\n\t\tthis._iRotationalVelocity = rotationalVelocity || new Vector3D();\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string\n\t{\n\t\tvar rotationRegister:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();\n\t\tanimationRegisterCache.setRegisterIndex(this, ParticleRotationalVelocityState.ROTATIONALVELOCITY_INDEX, rotationRegister.index);\n\n\t\tvar nrmVel:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\tanimationRegisterCache.addVertexTempUsages(nrmVel, 1);\n\n\t\tvar xAxis:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\tanimationRegisterCache.addVertexTempUsages(xAxis, 1);\n\n\t\tvar temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\tanimationRegisterCache.addVertexTempUsages(temp, 1);\n\t\tvar Rtemp:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index);\n\t\tvar R_rev:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\tR_rev = new ShaderRegisterElement(R_rev.regName, R_rev.index);\n\n\t\tvar cos:ShaderRegisterElement = new ShaderRegisterElement(Rtemp.regName, Rtemp.index, 3);\n\t\tvar sin:ShaderRegisterElement = new ShaderRegisterElement(R_rev.regName, R_rev.index, 3);\n\n\t\tanimationRegisterCache.removeVertexTempUsage(nrmVel);\n\t\tanimationRegisterCache.removeVertexTempUsage(xAxis);\n\t\tanimationRegisterCache.removeVertexTempUsage(temp);\n\n\t\tvar code:string = \"\";\n\t\tcode += \"mov \" + nrmVel + \".xyz,\" + rotationRegister + \".xyz\\n\";\n\t\tcode += \"mov \" + nrmVel + \".w,\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\n\t\tcode += \"mul \" + cos + \",\" + animationRegisterCache.vertexTime + \",\" + rotationRegister + \".w\\n\";\n\n\t\tcode += \"sin \" + sin + \",\" + cos + \"\\n\";\n\t\tcode += \"cos \" + cos + \",\" + cos + \"\\n\";\n\n\t\tcode += \"mul \" + Rtemp + \".xyz,\" + sin + \",\" + nrmVel + \".xyz\\n\";\n\n\t\tcode += \"mul \" + R_rev + \".xyz,\" + sin + \",\" + nrmVel + \".xyz\\n\";\n\t\tcode += \"neg \" + R_rev + \".xyz,\" + R_rev + \".xyz\\n\";\n\n\t\t//nrmVel and xAxis are used as temp register\n\t\tcode += \"crs \" + nrmVel + \".xyz,\" + Rtemp + \".xyz,\" + animationRegisterCache.scaleAndRotateTarget + \".xyz\\n\";\n\n\t\tcode += \"mul \" + xAxis + \".xyz,\" + cos + \",\" + animationRegisterCache.scaleAndRotateTarget + \".xyz\\n\";\n\t\tcode += \"add \" + nrmVel + \".xyz,\" + nrmVel + \".xyz,\" + xAxis + \".xyz\\n\";\n\t\tcode += \"dp3 \" + xAxis + \".w,\" + Rtemp + \".xyz,\" + animationRegisterCache.scaleAndRotateTarget + \".xyz\\n\";\n\t\tcode += \"neg \" + nrmVel + \".w,\" + xAxis + \".w\\n\";\n\n\t\tcode += \"crs \" + Rtemp + \".xyz,\" + nrmVel + \".xyz,\" + R_rev + \".xyz\\n\";\n\n\t\t//use cos as R_rev.w\n\t\tcode += \"mul \" + xAxis + \".xyzw,\" + nrmVel + \".xyzw,\" + cos + \"\\n\";\n\t\tcode += \"add \" + Rtemp + \".xyz,\" + Rtemp + \".xyz,\" + xAxis + \".xyz\\n\";\n\t\tcode += \"mul \" + xAxis + \".xyz,\" + nrmVel + \".w,\" + R_rev + \".xyz\\n\";\n\n\t\tcode += \"add \" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + Rtemp + \".xyz,\" + xAxis + \".xyz\\n\";\n\n\t\tvar len:number /*int*/ = animationRegisterCache.rotationRegisters.length;\n\t\tfor (var i:number /*int*/ = 0; i < len; i++) {\n\t\t\tcode += \"mov \" + nrmVel + \".xyz,\" + rotationRegister + \".xyz\\n\";\n\t\t\tcode += \"mov \" + nrmVel + \".w,\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\tcode += \"mul \" + cos + \",\" + animationRegisterCache.vertexTime + \",\" + rotationRegister + \".w\\n\";\n\t\t\tcode += \"sin \" + sin + \",\" + cos + \"\\n\";\n\t\t\tcode += \"cos \" + cos + \",\" + cos + \"\\n\";\n\t\t\tcode += \"mul \" + Rtemp + \".xyz,\" + sin + \",\" + nrmVel + \".xyz\\n\";\n\t\t\tcode += \"mul \" + R_rev + \".xyz,\" + sin + \",\" + nrmVel + \".xyz\\n\";\n\t\t\tcode += \"neg \" + R_rev + \".xyz,\" + R_rev + \".xyz\\n\";\n\t\t\tcode += \"crs \" + nrmVel + \".xyz,\" + Rtemp + \".xyz,\" + animationRegisterCache.rotationRegisters[i] + \".xyz\\n\";\n\t\t\tcode += \"mul \" + xAxis + \".xyz,\" + cos + \",\" + animationRegisterCache.rotationRegisters[i] + \"\\n\";\n\t\t\tcode += \"add \" + nrmVel + \".xyz,\" + nrmVel + \".xyz,\" + xAxis + \".xyz\\n\";\n\t\t\tcode += \"dp3 \" + xAxis + \".w,\" + Rtemp + \".xyz,\" + animationRegisterCache.rotationRegisters[i] + \"\\n\";\n\t\t\tcode += \"neg \" + nrmVel + \".w,\" + xAxis + \".w\\n\";\n\t\t\tcode += \"crs \" + Rtemp + \".xyz,\" + nrmVel + \".xyz,\" + R_rev + \".xyz\\n\";\n\t\t\tcode += \"mul \" + xAxis + \".xyzw,\" + nrmVel + \".xyzw,\" + cos + \"\\n\";\n\t\t\tcode += \"add \" + Rtemp + \".xyz,\" + Rtemp + \".xyz,\" + xAxis + \".xyz\\n\";\n\t\t\tcode += \"mul \" + xAxis + \".xyz,\" + nrmVel + \".w,\" + R_rev + \".xyz\\n\";\n\t\t\tcode += \"add \" + animationRegisterCache.rotationRegisters[i] + \",\" + Rtemp + \".xyz,\" + xAxis + \".xyz\\n\";\n\t\t}\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAnimationState(animator:AnimatorBase):ParticleRotationalVelocityState\n\t{\n\t\treturn <ParticleRotationalVelocityState> animator.getAnimationState(this);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _iGeneratePropertyOfOneParticle(param:ParticleProperties)\n\t{\n\t\t//(Vector3d.x,Vector3d.y,Vector3d.z) is rotation axis,Vector3d.w is cycle duration\n\t\tvar rotate:Vector3D = param[ParticleRotationalVelocityNode.ROTATIONALVELOCITY_VECTOR3D];\n\t\tif (!rotate)\n\t\t\tthrow(new Error(\"there is no \" + ParticleRotationalVelocityNode.ROTATIONALVELOCITY_VECTOR3D + \" in param!\"));\n\n\t\tif (rotate.length <= 0)\n\t\t\trotate.z = 1; //set the default direction\n\t\telse\n\t\t\trotate.normalize();\n\n\t\tthis._pOneData[0] = rotate.x;\n\t\tthis._pOneData[1] = rotate.y;\n\t\tthis._pOneData[2] = rotate.z;\n\t\tif (rotate.w <= 0)\n\t\t\tthrow(new Error(\"the cycle duration must greater than zero\"));\n\t\t// it's used as angle/2 in agal\n\t\tthis._pOneData[3] = Math.PI/rotate.w;\n\t}\n}\n\nexport = ParticleRotationalVelocityNode;"]}
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleRotationalVelocityNode.ts b/lib/animators/nodes/ParticleRotationalVelocityNode.ts
new file mode 100644
index 000000000..551851617
--- /dev/null
+++ b/lib/animators/nodes/ParticleRotationalVelocityNode.ts
@@ -0,0 +1,156 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleRotationalVelocityState = require("awayjs-renderergl/lib/animators/states/ParticleRotationalVelocityState");
+
+/**
+ * A particle animation node used to set the starting rotational velocity of a particle.
+ */
+class ParticleRotationalVelocityNode extends ParticleNodeBase
+{
+ /** @private */
+ public _iRotationalVelocity:Vector3D;
+
+ /**
+ * Reference for rotational velocity node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
object representing the rotational velocity around an axis of the particle.
+ */
+ public static ROTATIONALVELOCITY_VECTOR3D:string = "RotationalVelocityVector3D";
+
+ /**
+ * Creates a new ParticleRotationalVelocityNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ */
+ constructor(mode:number /*uint*/, rotationalVelocity:Vector3D = null)
+ {
+ super("ParticleRotationalVelocity", mode, 4);
+
+ this._pStateClass = ParticleRotationalVelocityState;
+
+ this._iRotationalVelocity = rotationalVelocity || new Vector3D();
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ var rotationRegister:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleRotationalVelocityState.ROTATIONALVELOCITY_INDEX, rotationRegister.index);
+
+ var nrmVel:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(nrmVel, 1);
+
+ var xAxis:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(xAxis, 1);
+
+ var temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(temp, 1);
+ var Rtemp:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index);
+ var R_rev:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ R_rev = new ShaderRegisterElement(R_rev.regName, R_rev.index);
+
+ var cos:ShaderRegisterElement = new ShaderRegisterElement(Rtemp.regName, Rtemp.index, 3);
+ var sin:ShaderRegisterElement = new ShaderRegisterElement(R_rev.regName, R_rev.index, 3);
+
+ animationRegisterCache.removeVertexTempUsage(nrmVel);
+ animationRegisterCache.removeVertexTempUsage(xAxis);
+ animationRegisterCache.removeVertexTempUsage(temp);
+
+ var code:string = "";
+ code += "mov " + nrmVel + ".xyz," + rotationRegister + ".xyz\n";
+ code += "mov " + nrmVel + ".w," + animationRegisterCache.vertexZeroConst + "\n";
+
+ code += "mul " + cos + "," + animationRegisterCache.vertexTime + "," + rotationRegister + ".w\n";
+
+ code += "sin " + sin + "," + cos + "\n";
+ code += "cos " + cos + "," + cos + "\n";
+
+ code += "mul " + Rtemp + ".xyz," + sin + "," + nrmVel + ".xyz\n";
+
+ code += "mul " + R_rev + ".xyz," + sin + "," + nrmVel + ".xyz\n";
+ code += "neg " + R_rev + ".xyz," + R_rev + ".xyz\n";
+
+ //nrmVel and xAxis are used as temp register
+ code += "crs " + nrmVel + ".xyz," + Rtemp + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz\n";
+
+ code += "mul " + xAxis + ".xyz," + cos + "," + animationRegisterCache.scaleAndRotateTarget + ".xyz\n";
+ code += "add " + nrmVel + ".xyz," + nrmVel + ".xyz," + xAxis + ".xyz\n";
+ code += "dp3 " + xAxis + ".w," + Rtemp + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz\n";
+ code += "neg " + nrmVel + ".w," + xAxis + ".w\n";
+
+ code += "crs " + Rtemp + ".xyz," + nrmVel + ".xyz," + R_rev + ".xyz\n";
+
+ //use cos as R_rev.w
+ code += "mul " + xAxis + ".xyzw," + nrmVel + ".xyzw," + cos + "\n";
+ code += "add " + Rtemp + ".xyz," + Rtemp + ".xyz," + xAxis + ".xyz\n";
+ code += "mul " + xAxis + ".xyz," + nrmVel + ".w," + R_rev + ".xyz\n";
+
+ code += "add " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + Rtemp + ".xyz," + xAxis + ".xyz\n";
+
+ var len:number /*int*/ = animationRegisterCache.rotationRegisters.length;
+ for (var i:number /*int*/ = 0; i < len; i++) {
+ code += "mov " + nrmVel + ".xyz," + rotationRegister + ".xyz\n";
+ code += "mov " + nrmVel + ".w," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mul " + cos + "," + animationRegisterCache.vertexTime + "," + rotationRegister + ".w\n";
+ code += "sin " + sin + "," + cos + "\n";
+ code += "cos " + cos + "," + cos + "\n";
+ code += "mul " + Rtemp + ".xyz," + sin + "," + nrmVel + ".xyz\n";
+ code += "mul " + R_rev + ".xyz," + sin + "," + nrmVel + ".xyz\n";
+ code += "neg " + R_rev + ".xyz," + R_rev + ".xyz\n";
+ code += "crs " + nrmVel + ".xyz," + Rtemp + ".xyz," + animationRegisterCache.rotationRegisters[i] + ".xyz\n";
+ code += "mul " + xAxis + ".xyz," + cos + "," + animationRegisterCache.rotationRegisters[i] + "\n";
+ code += "add " + nrmVel + ".xyz," + nrmVel + ".xyz," + xAxis + ".xyz\n";
+ code += "dp3 " + xAxis + ".w," + Rtemp + ".xyz," + animationRegisterCache.rotationRegisters[i] + "\n";
+ code += "neg " + nrmVel + ".w," + xAxis + ".w\n";
+ code += "crs " + Rtemp + ".xyz," + nrmVel + ".xyz," + R_rev + ".xyz\n";
+ code += "mul " + xAxis + ".xyzw," + nrmVel + ".xyzw," + cos + "\n";
+ code += "add " + Rtemp + ".xyz," + Rtemp + ".xyz," + xAxis + ".xyz\n";
+ code += "mul " + xAxis + ".xyz," + nrmVel + ".w," + R_rev + ".xyz\n";
+ code += "add " + animationRegisterCache.rotationRegisters[i] + "," + Rtemp + ".xyz," + xAxis + ".xyz\n";
+ }
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):ParticleRotationalVelocityState
+ {
+ return animator.getAnimationState(this);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iGeneratePropertyOfOneParticle(param:ParticleProperties)
+ {
+ //(Vector3d.x,Vector3d.y,Vector3d.z) is rotation axis,Vector3d.w is cycle duration
+ var rotate:Vector3D = param[ParticleRotationalVelocityNode.ROTATIONALVELOCITY_VECTOR3D];
+ if (!rotate)
+ throw(new Error("there is no " + ParticleRotationalVelocityNode.ROTATIONALVELOCITY_VECTOR3D + " in param!"));
+
+ if (rotate.length <= 0)
+ rotate.z = 1; //set the default direction
+ else
+ rotate.normalize();
+
+ this._pOneData[0] = rotate.x;
+ this._pOneData[1] = rotate.y;
+ this._pOneData[2] = rotate.z;
+ if (rotate.w <= 0)
+ throw(new Error("the cycle duration must greater than zero"));
+ // it's used as angle/2 in agal
+ this._pOneData[3] = Math.PI/rotate.w;
+ }
+}
+
+export = ParticleRotationalVelocityNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleScaleNode.js b/lib/animators/nodes/ParticleScaleNode.js
new file mode 100755
index 000000000..e2c40f83e
--- /dev/null
+++ b/lib/animators/nodes/ParticleScaleNode.js
@@ -0,0 +1,95 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+var ParticleScaleState = require("awayjs-renderergl/lib/animators/states/ParticleScaleState");
+/**
+ * A particle animation node used to control the scale variation of a particle over time.
+ */
+var ParticleScaleNode = (function (_super) {
+ __extends(ParticleScaleNode, _super);
+ /**
+ * Creates a new ParticleScaleNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] usesCycle Defines whether the node uses the cycleDuration
property in the shader to calculate the period of animation independent of particle duration. Defaults to false.
+ * @param [optional] usesPhase Defines whether the node uses the cyclePhase
property in the shader to calculate a starting offset to the animation cycle. Defaults to false.
+ * @param [optional] minScale Defines the default min scale transform of the node, when in global mode. Defaults to 1.
+ * @param [optional] maxScale Defines the default max color transform of the node, when in global mode. Defaults to 1.
+ * @param [optional] cycleDuration Defines the default duration of the animation in seconds, used as a period independent of particle duration when in global mode. Defaults to 1.
+ * @param [optional] cyclePhase Defines the default phase of the cycle in degrees, used as the starting offset of the cycle when in global mode. Defaults to 0.
+ */
+ function ParticleScaleNode(mode /*uint*/, usesCycle, usesPhase, minScale, maxScale, cycleDuration, cyclePhase) {
+ if (minScale === void 0) { minScale = 1; }
+ if (maxScale === void 0) { maxScale = 1; }
+ if (cycleDuration === void 0) { cycleDuration = 1; }
+ if (cyclePhase === void 0) { cyclePhase = 0; }
+ _super.call(this, "ParticleScale", mode, (usesCycle && usesPhase) ? 4 : ((usesCycle || usesPhase) ? 3 : 2), 3);
+ this._pStateClass = ParticleScaleState;
+ this._iUsesCycle = usesCycle;
+ this._iUsesPhase = usesPhase;
+ this._iMinScale = minScale;
+ this._iMaxScale = maxScale;
+ this._iCycleDuration = cycleDuration;
+ this._iCyclePhase = cyclePhase;
+ }
+ /**
+ * @inheritDoc
+ */
+ ParticleScaleNode.prototype.getAGALVertexCode = function (shaderObject, animationRegisterCache) {
+ var code = "";
+ var temp = animationRegisterCache.getFreeVertexSingleTemp();
+ var scaleRegister = (this._pMode == ParticlePropertiesMode.GLOBAL) ? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleScaleState.SCALE_INDEX, scaleRegister.index);
+ if (this._iUsesCycle) {
+ code += "mul " + temp + "," + animationRegisterCache.vertexTime + "," + scaleRegister + ".z\n";
+ if (this._iUsesPhase)
+ code += "add " + temp + "," + temp + "," + scaleRegister + ".w\n";
+ code += "sin " + temp + "," + temp + "\n";
+ }
+ code += "mul " + temp + "," + scaleRegister + ".y," + ((this._iUsesCycle) ? temp : animationRegisterCache.vertexLife) + "\n";
+ code += "add " + temp + "," + scaleRegister + ".x," + temp + "\n";
+ code += "mul " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz," + temp + "\n";
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleScaleNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleScaleNode.prototype._iGeneratePropertyOfOneParticle = function (param) {
+ var scale = param[ParticleScaleNode.SCALE_VECTOR3D];
+ if (!scale)
+ throw (new Error("there is no " + ParticleScaleNode.SCALE_VECTOR3D + " in param!"));
+ if (this._iUsesCycle) {
+ this._pOneData[0] = (scale.x + scale.y) / 2;
+ this._pOneData[1] = Math.abs(scale.x - scale.y) / 2;
+ if (scale.z <= 0)
+ throw (new Error("the cycle duration must be greater than zero"));
+ this._pOneData[2] = Math.PI * 2 / scale.z;
+ if (this._iUsesPhase)
+ this._pOneData[3] = scale.w * Math.PI / 180;
+ }
+ else {
+ this._pOneData[0] = scale.x;
+ this._pOneData[1] = scale.y - scale.x;
+ }
+ };
+ /**
+ * Reference for scale node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
representing the min scale (x), max scale(y), optional cycle speed (z) and phase offset (w) applied to the particle.
+ */
+ ParticleScaleNode.SCALE_VECTOR3D = "ScaleVector3D";
+ return ParticleScaleNode;
+})(ParticleNodeBase);
+module.exports = ParticleScaleNode;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/nodes/particlescalenode.ts"],"names":["ParticleScaleNode","ParticleScaleNode.constructor","ParticleScaleNode.getAGALVertexCode","ParticleScaleNode.getAnimationState","ParticleScaleNode._iGeneratePropertyOfOneParticle"],"mappings":"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AuCA,KAAwBA;QAE9DI,IAAIA,KAAKA,GAAYA,KAAKA,CAACA,iBAAiBA,CAACA,cAAcA,CAACA,CAACA;QAC7DA,EAAEA,CAACA,CAACA,CAACA,KAAKA,CAACA;YACVA,MAAKA,CAACA,IAAIA,KAAKA,CAACA,cAAcA,GAAGA,iBAAiBA,CAACA,cAAcA,GAAGA,YAAYA,CAACA,CAACA,CAACA;QAEpFA,EAAEA,CAACA,CAACA,IAAIA,CAACA,WAAWA,CAACA,CAACA,CAACA;YACtBA,IAAIA,CAACA,SAASA,CAACA,CAACA,CAACA,GAAGA,CAACA,KAAKA,CAACA,CAACA,GAAGA,KAAKA,CAACA,CAACA,CAACA,GAACA,CAACA,CAACA;YAC1CA,IAAIA,CAACA,SAASA,CAACA,CAACA,CAACA,GAAGA,IAAIA,CAACA,GAAGA,CAACA,KAAKA,CAACA,CAACA,GAAGA,KAAKA,CAACA,CAACA,CAACA,GAACA,CAACA,CAACA;YAClDA,EAAEA,CAACA,CAACA,KAAKA,CAACA,CAACA,IAAIA,CAACA,CAACA;gBAChBA,MAAKA,CAACA,IAAIA,KAAKA,CAACA,8CAA8CA,CAACA,CAACA,CAACA;YAClEA,IAAIA,CAACA,SAASA,CAACA,CAACA,CAACA,GAAGA,IAAIA,CAACA,EAAEA,GAACA,CAACA,GAACA,KAAKA,CAACA,CAACA,CAACA;YACtCA,EAAEA,CAACA,CAACA,IAAIA,CAACA,WAAWA,CAACA;gBACpBA,IAAIA,CAACA,SAASA,CAACA,CAACA,CAACA,GAAGA,KAAKA,CAACA,CAACA,GAACA,IAAIA,CAACA,EAAEA,GAACA,GAAGA,CAACA;QAC1CA,CAACA;QAACA,IAAIA,CAACA,CAACA;YACPA,IAAIA,CAACA,SAASA,CAACA,CAACA,CAACA,GAAGA,KAAKA,CAACA,CAACA,CAACA;YAC5BA,IAAIA,CAACA,SAASA,CAACA,CAACA,CAACA,GAAGA,KAAKA,CAACA,CAACA,GAAGA,KAAKA,CAACA,CAACA,CAACA;QACvCA,CAACA;IACFA,CAACA;IAxFDJ;;;OAGGA;IACWA,gCAAcA,GAAUA,eAAeA,CAACA;IAqFvDA,wBAACA;AAADA,CA1GA,AA0GCA,EA1G+B,gBAAgB,EA0G/C;AAED,AAA2B,iBAAlB,iBAAiB,CAAC","file":"animators/nodes/ParticleScaleNode.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\n\nimport ParticleProperties\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleProperties\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleNodeBase\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleNodeBase\");\nimport ParticleScaleState\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleScaleState\");\n\n/**\n * A particle animation node used to control the scale variation of a particle over time.\n */\nclass ParticleScaleNode extends ParticleNodeBase\n{\n\t/** @private */\n\tpublic _iUsesCycle:boolean;\n\n\t/** @private */\n\tpublic _iUsesPhase:boolean;\n\n\t/** @private */\n\tpublic _iMinScale:number;\n\t/** @private */\n\tpublic _iMaxScale:number;\n\t/** @private */\n\tpublic _iCycleDuration:number;\n\t/** @private */\n\tpublic _iCyclePhase:number;\n\n\t/**\n\t * Reference for scale node properties on a single particle (when in local property mode).\n\t * Expects a <code>Vector3D</code> representing the min scale (x), max scale(y), optional cycle speed (z) and phase offset (w) applied to the particle.\n\t */\n\tpublic static SCALE_VECTOR3D:string = \"ScaleVector3D\";\n\n\t/**\n\t * Creates a new <code>ParticleScaleNode</code>\n\t *\n\t * @param               mode            Defines whether the mode of operation acts on local properties of a particle or global properties of the node.\n\t * @param    [optional] usesCycle       Defines whether the node uses the <code>cycleDuration</code> property in the shader to calculate the period of animation independent of particle duration. Defaults to false.\n\t * @param    [optional] usesPhase       Defines whether the node uses the <code>cyclePhase</code> property in the shader to calculate a starting offset to the animation cycle. Defaults to false.\n\t * @param    [optional] minScale        Defines the default min scale transform of the node, when in global mode. Defaults to 1.\n\t * @param    [optional] maxScale        Defines the default max color transform of the node, when in global mode. Defaults to 1.\n\t * @param    [optional] cycleDuration   Defines the default duration of the animation in seconds, used as a period independent of particle duration when in global mode. Defaults to 1.\n\t * @param    [optional] cyclePhase      Defines the default phase of the cycle in degrees, used as the starting offset of the cycle when in global mode. Defaults to 0.\n\t */\n\tconstructor(mode:number /*uint*/, usesCycle:boolean, usesPhase:boolean, minScale:number = 1, maxScale:number = 1, cycleDuration:number = 1, cyclePhase:number = 0)\n\t{\n\t\tsuper(\"ParticleScale\", mode, (usesCycle && usesPhase)? 4 : ((usesCycle || usesPhase)? 3 : 2), 3);\n\n\t\tthis._pStateClass = ParticleScaleState;\n\n\t\tthis._iUsesCycle = usesCycle;\n\t\tthis._iUsesPhase = usesPhase;\n\n\t\tthis._iMinScale = minScale;\n\t\tthis._iMaxScale = maxScale;\n\t\tthis._iCycleDuration = cycleDuration;\n\t\tthis._iCyclePhase = cyclePhase;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string\n\t{\n\t\tvar code:string = \"\";\n\t\tvar temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexSingleTemp();\n\n\t\tvar scaleRegister:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();\n\t\tanimationRegisterCache.setRegisterIndex(this, ParticleScaleState.SCALE_INDEX, scaleRegister.index);\n\n\t\tif (this._iUsesCycle) {\n\t\t\tcode += \"mul \" + temp + \",\" + animationRegisterCache.vertexTime + \",\" + scaleRegister + \".z\\n\";\n\n\t\t\tif (this._iUsesPhase)\n\t\t\t\tcode += \"add \" + temp + \",\" + temp + \",\" + scaleRegister + \".w\\n\";\n\n\t\t\tcode += \"sin \" + temp + \",\" + temp + \"\\n\";\n\t\t}\n\n\t\tcode += \"mul \" + temp + \",\" + scaleRegister + \".y,\" + ((this._iUsesCycle)? temp : animationRegisterCache.vertexLife) + \"\\n\";\n\t\tcode += \"add \" + temp + \",\" + scaleRegister + \".x,\" + temp + \"\\n\";\n\t\tcode += \"mul \" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + temp + \"\\n\";\n\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAnimationState(animator:AnimatorBase):ParticleScaleState\n\t{\n\t\treturn <ParticleScaleState> animator.getAnimationState(this);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _iGeneratePropertyOfOneParticle(param:ParticleProperties)\n\t{\n\t\tvar scale:Vector3D = param[ParticleScaleNode.SCALE_VECTOR3D];\n\t\tif (!scale)\n\t\t\tthrow(new Error(\"there is no \" + ParticleScaleNode.SCALE_VECTOR3D + \" in param!\"));\n\n\t\tif (this._iUsesCycle) {\n\t\t\tthis._pOneData[0] = (scale.x + scale.y)/2;\n\t\t\tthis._pOneData[1] = Math.abs(scale.x - scale.y)/2;\n\t\t\tif (scale.z <= 0)\n\t\t\t\tthrow(new Error(\"the cycle duration must be greater than zero\"));\n\t\t\tthis._pOneData[2] = Math.PI*2/scale.z;\n\t\t\tif (this._iUsesPhase)\n\t\t\t\tthis._pOneData[3] = scale.w*Math.PI/180;\n\t\t} else {\n\t\t\tthis._pOneData[0] = scale.x;\n\t\t\tthis._pOneData[1] = scale.y - scale.x;\n\t\t}\n\t}\n}\n\nexport = ParticleScaleNode;"]}
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleScaleNode.ts b/lib/animators/nodes/ParticleScaleNode.ts
new file mode 100644
index 000000000..f150cef24
--- /dev/null
+++ b/lib/animators/nodes/ParticleScaleNode.ts
@@ -0,0 +1,124 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleScaleState = require("awayjs-renderergl/lib/animators/states/ParticleScaleState");
+
+/**
+ * A particle animation node used to control the scale variation of a particle over time.
+ */
+class ParticleScaleNode extends ParticleNodeBase
+{
+ /** @private */
+ public _iUsesCycle:boolean;
+
+ /** @private */
+ public _iUsesPhase:boolean;
+
+ /** @private */
+ public _iMinScale:number;
+ /** @private */
+ public _iMaxScale:number;
+ /** @private */
+ public _iCycleDuration:number;
+ /** @private */
+ public _iCyclePhase:number;
+
+ /**
+ * Reference for scale node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
representing the min scale (x), max scale(y), optional cycle speed (z) and phase offset (w) applied to the particle.
+ */
+ public static SCALE_VECTOR3D:string = "ScaleVector3D";
+
+ /**
+ * Creates a new ParticleScaleNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] usesCycle Defines whether the node uses the cycleDuration
property in the shader to calculate the period of animation independent of particle duration. Defaults to false.
+ * @param [optional] usesPhase Defines whether the node uses the cyclePhase
property in the shader to calculate a starting offset to the animation cycle. Defaults to false.
+ * @param [optional] minScale Defines the default min scale transform of the node, when in global mode. Defaults to 1.
+ * @param [optional] maxScale Defines the default max color transform of the node, when in global mode. Defaults to 1.
+ * @param [optional] cycleDuration Defines the default duration of the animation in seconds, used as a period independent of particle duration when in global mode. Defaults to 1.
+ * @param [optional] cyclePhase Defines the default phase of the cycle in degrees, used as the starting offset of the cycle when in global mode. Defaults to 0.
+ */
+ constructor(mode:number /*uint*/, usesCycle:boolean, usesPhase:boolean, minScale:number = 1, maxScale:number = 1, cycleDuration:number = 1, cyclePhase:number = 0)
+ {
+ super("ParticleScale", mode, (usesCycle && usesPhase)? 4 : ((usesCycle || usesPhase)? 3 : 2), 3);
+
+ this._pStateClass = ParticleScaleState;
+
+ this._iUsesCycle = usesCycle;
+ this._iUsesPhase = usesPhase;
+
+ this._iMinScale = minScale;
+ this._iMaxScale = maxScale;
+ this._iCycleDuration = cycleDuration;
+ this._iCyclePhase = cyclePhase;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ var code:string = "";
+ var temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexSingleTemp();
+
+ var scaleRegister:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleScaleState.SCALE_INDEX, scaleRegister.index);
+
+ if (this._iUsesCycle) {
+ code += "mul " + temp + "," + animationRegisterCache.vertexTime + "," + scaleRegister + ".z\n";
+
+ if (this._iUsesPhase)
+ code += "add " + temp + "," + temp + "," + scaleRegister + ".w\n";
+
+ code += "sin " + temp + "," + temp + "\n";
+ }
+
+ code += "mul " + temp + "," + scaleRegister + ".y," + ((this._iUsesCycle)? temp : animationRegisterCache.vertexLife) + "\n";
+ code += "add " + temp + "," + scaleRegister + ".x," + temp + "\n";
+ code += "mul " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz," + temp + "\n";
+
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):ParticleScaleState
+ {
+ return animator.getAnimationState(this);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iGeneratePropertyOfOneParticle(param:ParticleProperties)
+ {
+ var scale:Vector3D = param[ParticleScaleNode.SCALE_VECTOR3D];
+ if (!scale)
+ throw(new Error("there is no " + ParticleScaleNode.SCALE_VECTOR3D + " in param!"));
+
+ if (this._iUsesCycle) {
+ this._pOneData[0] = (scale.x + scale.y)/2;
+ this._pOneData[1] = Math.abs(scale.x - scale.y)/2;
+ if (scale.z <= 0)
+ throw(new Error("the cycle duration must be greater than zero"));
+ this._pOneData[2] = Math.PI*2/scale.z;
+ if (this._iUsesPhase)
+ this._pOneData[3] = scale.w*Math.PI/180;
+ } else {
+ this._pOneData[0] = scale.x;
+ this._pOneData[1] = scale.y - scale.x;
+ }
+ }
+}
+
+export = ParticleScaleNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleSegmentedColorNode.js b/lib/animators/nodes/ParticleSegmentedColorNode.js
new file mode 100755
index 000000000..edfa4092e
--- /dev/null
+++ b/lib/animators/nodes/ParticleSegmentedColorNode.js
@@ -0,0 +1,151 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+var ParticleAnimationSet = require("awayjs-renderergl/lib/animators/ParticleAnimationSet");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+var ParticleSegmentedColorState = require("awayjs-renderergl/lib/animators/states/ParticleSegmentedColorState");
+/**
+ *
+ */
+var ParticleSegmentedColorNode = (function (_super) {
+ __extends(ParticleSegmentedColorNode, _super);
+ function ParticleSegmentedColorNode(usesMultiplier, usesOffset, numSegmentPoint /*int*/, startColor, endColor, segmentPoints) {
+ //because of the stage3d register limitation, it only support the global mode
+ _super.call(this, "ParticleSegmentedColor", ParticlePropertiesMode.GLOBAL, 0, ParticleAnimationSet.COLOR_PRIORITY);
+ this._pStateClass = ParticleSegmentedColorState;
+ if (numSegmentPoint > 4)
+ throw (new Error("the numSegmentPoint must be less or equal 4"));
+ this._iUsesMultiplier = usesMultiplier;
+ this._iUsesOffset = usesOffset;
+ this._iNumSegmentPoint = numSegmentPoint;
+ this._iStartColor = startColor;
+ this._iEndColor = endColor;
+ this._iSegmentPoints = segmentPoints;
+ }
+ /**
+ * @inheritDoc
+ */
+ ParticleSegmentedColorNode.prototype._iProcessAnimationSetting = function (particleAnimationSet) {
+ if (this._iUsesMultiplier)
+ particleAnimationSet.hasColorMulNode = true;
+ if (this._iUsesOffset)
+ particleAnimationSet.hasColorAddNode = true;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleSegmentedColorNode.prototype.getAGALVertexCode = function (shaderObject, animationRegisterCache) {
+ var code = "";
+ if (animationRegisterCache.needFragmentAnimation) {
+ var accMultiplierColor;
+ //var accOffsetColor:ShaderRegisterElement;
+ if (this._iUsesMultiplier) {
+ accMultiplierColor = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(accMultiplierColor, 1);
+ }
+ var tempColor = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(tempColor, 1);
+ var temp = animationRegisterCache.getFreeVertexVectorTemp();
+ var accTime = new ShaderRegisterElement(temp.regName, temp.index, 0);
+ var tempTime = new ShaderRegisterElement(temp.regName, temp.index, 1);
+ if (this._iUsesMultiplier)
+ animationRegisterCache.removeVertexTempUsage(accMultiplierColor);
+ animationRegisterCache.removeVertexTempUsage(tempColor);
+ //for saving all the life values (at most 4)
+ var lifeTimeRegister = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleSegmentedColorState.TIME_DATA_INDEX, lifeTimeRegister.index);
+ var i /*int*/;
+ var startMulValue;
+ var deltaMulValues;
+ if (this._iUsesMultiplier) {
+ startMulValue = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleSegmentedColorState.START_MULTIPLIER_INDEX, startMulValue.index);
+ deltaMulValues = new Array();
+ for (i = 0; i < this._iNumSegmentPoint + 1; i++)
+ deltaMulValues.push(animationRegisterCache.getFreeVertexConstant());
+ }
+ var startOffsetValue;
+ var deltaOffsetValues;
+ if (this._iUsesOffset) {
+ startOffsetValue = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleSegmentedColorState.START_OFFSET_INDEX, startOffsetValue.index);
+ deltaOffsetValues = new Array();
+ for (i = 0; i < this._iNumSegmentPoint + 1; i++)
+ deltaOffsetValues.push(animationRegisterCache.getFreeVertexConstant());
+ }
+ if (this._iUsesMultiplier)
+ code += "mov " + accMultiplierColor + "," + startMulValue + "\n";
+ if (this._iUsesOffset)
+ code += "add " + animationRegisterCache.colorAddTarget + "," + animationRegisterCache.colorAddTarget + "," + startOffsetValue + "\n";
+ for (i = 0; i < this._iNumSegmentPoint; i++) {
+ switch (i) {
+ case 0:
+ code += "min " + tempTime + "," + animationRegisterCache.vertexLife + "," + lifeTimeRegister + ".x\n";
+ break;
+ case 1:
+ code += "sub " + accTime + "," + animationRegisterCache.vertexLife + "," + lifeTimeRegister + ".x\n";
+ code += "max " + tempTime + "," + accTime + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "min " + tempTime + "," + tempTime + "," + lifeTimeRegister + ".y\n";
+ break;
+ case 2:
+ code += "sub " + accTime + "," + accTime + "," + lifeTimeRegister + ".y\n";
+ code += "max " + tempTime + "," + accTime + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "min " + tempTime + "," + tempTime + "," + lifeTimeRegister + ".z\n";
+ break;
+ case 3:
+ code += "sub " + accTime + "," + accTime + "," + lifeTimeRegister + ".z\n";
+ code += "max " + tempTime + "," + accTime + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "min " + tempTime + "," + tempTime + "," + lifeTimeRegister + ".w\n";
+ break;
+ }
+ if (this._iUsesMultiplier) {
+ code += "mul " + tempColor + "," + tempTime + "," + deltaMulValues[i] + "\n";
+ code += "add " + accMultiplierColor + "," + accMultiplierColor + "," + tempColor + "\n";
+ }
+ if (this._iUsesOffset) {
+ code += "mul " + tempColor + "," + tempTime + "," + deltaOffsetValues[i] + "\n";
+ code += "add " + animationRegisterCache.colorAddTarget + "," + animationRegisterCache.colorAddTarget + "," + tempColor + "\n";
+ }
+ }
+ //for the last segment:
+ if (this._iNumSegmentPoint == 0)
+ tempTime = animationRegisterCache.vertexLife;
+ else {
+ switch (this._iNumSegmentPoint) {
+ case 1:
+ code += "sub " + accTime + "," + animationRegisterCache.vertexLife + "," + lifeTimeRegister + ".x\n";
+ break;
+ case 2:
+ code += "sub " + accTime + "," + accTime + "," + lifeTimeRegister + ".y\n";
+ break;
+ case 3:
+ code += "sub " + accTime + "," + accTime + "," + lifeTimeRegister + ".z\n";
+ break;
+ case 4:
+ code += "sub " + accTime + "," + accTime + "," + lifeTimeRegister + ".w\n";
+ break;
+ }
+ code += "max " + tempTime + "," + accTime + "," + animationRegisterCache.vertexZeroConst + "\n";
+ }
+ if (this._iUsesMultiplier) {
+ code += "mul " + tempColor + "," + tempTime + "," + deltaMulValues[this._iNumSegmentPoint] + "\n";
+ code += "add " + accMultiplierColor + "," + accMultiplierColor + "," + tempColor + "\n";
+ code += "mul " + animationRegisterCache.colorMulTarget + "," + animationRegisterCache.colorMulTarget + "," + accMultiplierColor + "\n";
+ }
+ if (this._iUsesOffset) {
+ code += "mul " + tempColor + "," + tempTime + "," + deltaOffsetValues[this._iNumSegmentPoint] + "\n";
+ code += "add " + animationRegisterCache.colorAddTarget + "," + animationRegisterCache.colorAddTarget + "," + tempColor + "\n";
+ }
+ }
+ return code;
+ };
+ return ParticleSegmentedColorNode;
+})(ParticleNodeBase);
+module.exports = ParticleSegmentedColorNode;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/nodes/particlesegmentedcolornode.ts"],"names":["ParticleSegmentedColorNode","ParticleSegmentedColorNode.constructor","ParticleSegmentedColorNode._iProcessAnimationSetting","ParticleSegmentedColorNode.getAGALVertexCode"],"mappings":"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","file":"animators/nodes/ParticleSegmentedColorNode.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import ColorTransform\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/ColorTransform\");\nimport Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\n\nimport ParticleAnimationSet\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimationSet\");\nimport ColorSegmentPoint\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ColorSegmentPoint\");\nimport ParticleProperties\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleProperties\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleNodeBase\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleNodeBase\");\nimport ParticleSegmentedColorState\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleSegmentedColorState\");\n\n/**\n *\n */\nclass ParticleSegmentedColorNode extends ParticleNodeBase\n{\n\t/** @private */\n\tpublic _iUsesMultiplier:boolean;\n\t/** @private */\n\tpublic _iUsesOffset:boolean;\n\t/** @private */\n\tpublic _iStartColor:ColorTransform;\n\t/** @private */\n\tpublic _iEndColor:ColorTransform;\n\t/** @private */\n\tpublic _iNumSegmentPoint:number /*int*/;\n\t/** @private */\n\tpublic _iSegmentPoints:Array<ColorSegmentPoint>;\n\n\tconstructor(usesMultiplier:boolean, usesOffset:boolean, numSegmentPoint:number /*int*/, startColor:ColorTransform, endColor:ColorTransform, segmentPoints:Array<ColorSegmentPoint>)\n\t{\n\t\t//because of the stage3d register limitation, it only support the global mode\n\t\tsuper(\"ParticleSegmentedColor\", ParticlePropertiesMode.GLOBAL, 0, ParticleAnimationSet.COLOR_PRIORITY);\n\n\t\tthis._pStateClass = ParticleSegmentedColorState;\n\n\t\tif (numSegmentPoint > 4)\n\t\t\tthrow(new Error(\"the numSegmentPoint must be less or equal 4\"));\n\t\tthis._iUsesMultiplier = usesMultiplier;\n\t\tthis._iUsesOffset = usesOffset;\n\t\tthis._iNumSegmentPoint = numSegmentPoint;\n\t\tthis._iStartColor = startColor;\n\t\tthis._iEndColor = endColor;\n\t\tthis._iSegmentPoints = segmentPoints;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _iProcessAnimationSetting(particleAnimationSet:ParticleAnimationSet)\n\t{\n\t\tif (this._iUsesMultiplier)\n\t\t\tparticleAnimationSet.hasColorMulNode = true;\n\t\tif (this._iUsesOffset)\n\t\t\tparticleAnimationSet.hasColorAddNode = true;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string\n\t{\n\t\tvar code:string = \"\";\n\t\tif (animationRegisterCache.needFragmentAnimation) {\n\t\t\tvar accMultiplierColor:ShaderRegisterElement;\n\t\t\t//var accOffsetColor:ShaderRegisterElement;\n\t\t\tif (this._iUsesMultiplier) {\n\t\t\t\taccMultiplierColor = animationRegisterCache.getFreeVertexVectorTemp();\n\t\t\t\tanimationRegisterCache.addVertexTempUsages(accMultiplierColor, 1);\n\t\t\t}\n\n\t\t\tvar tempColor:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\t\tanimationRegisterCache.addVertexTempUsages(tempColor, 1);\n\n\t\t\tvar temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\t\tvar accTime:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 0);\n\t\t\tvar tempTime:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 1);\n\n\t\t\tif (this._iUsesMultiplier)\n\t\t\t\tanimationRegisterCache.removeVertexTempUsage(accMultiplierColor);\n\n\t\t\tanimationRegisterCache.removeVertexTempUsage(tempColor);\n\n\t\t\t//for saving all the life values (at most 4)\n\t\t\tvar lifeTimeRegister:ShaderRegisterElement = animationRegisterCache.getFreeVertexConstant();\n\t\t\tanimationRegisterCache.setRegisterIndex(this, ParticleSegmentedColorState.TIME_DATA_INDEX, lifeTimeRegister.index);\n\n\t\t\tvar i:number /*int*/;\n\n\t\t\tvar startMulValue:ShaderRegisterElement;\n\t\t\tvar deltaMulValues:Array<ShaderRegisterElement>;\n\t\t\tif (this._iUsesMultiplier) {\n\t\t\t\tstartMulValue = animationRegisterCache.getFreeVertexConstant();\n\t\t\t\tanimationRegisterCache.setRegisterIndex(this, ParticleSegmentedColorState.START_MULTIPLIER_INDEX, startMulValue.index);\n\t\t\t\tdeltaMulValues = new Array<ShaderRegisterElement>();\n\t\t\t\tfor (i = 0; i < this._iNumSegmentPoint + 1; i++)\n\t\t\t\t\tdeltaMulValues.push(animationRegisterCache.getFreeVertexConstant());\n\t\t\t}\n\n\t\t\tvar startOffsetValue:ShaderRegisterElement;\n\t\t\tvar deltaOffsetValues:Array<ShaderRegisterElement>;\n\t\t\tif (this._iUsesOffset) {\n\t\t\t\tstartOffsetValue = animationRegisterCache.getFreeVertexConstant();\n\t\t\t\tanimationRegisterCache.setRegisterIndex(this, ParticleSegmentedColorState.START_OFFSET_INDEX, startOffsetValue.index);\n\t\t\t\tdeltaOffsetValues = new Array<ShaderRegisterElement>();\n\t\t\t\tfor (i = 0; i < this._iNumSegmentPoint + 1; i++)\n\t\t\t\t\tdeltaOffsetValues.push(animationRegisterCache.getFreeVertexConstant());\n\t\t\t}\n\n\t\t\tif (this._iUsesMultiplier)\n\t\t\t\tcode += \"mov \" + accMultiplierColor + \",\" + startMulValue + \"\\n\";\n\t\t\tif (this._iUsesOffset)\n\t\t\t\tcode += \"add \" + animationRegisterCache.colorAddTarget + \",\" + animationRegisterCache.colorAddTarget + \",\" + startOffsetValue + \"\\n\";\n\n\t\t\tfor (i = 0; i < this._iNumSegmentPoint; i++) {\n\t\t\t\tswitch (i) {\n\t\t\t\t\tcase 0:\n\t\t\t\t\t\tcode += \"min \" + tempTime + \",\" + animationRegisterCache.vertexLife + \",\" + lifeTimeRegister + \".x\\n\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 1:\n\t\t\t\t\t\tcode += \"sub \" + accTime + \",\" + animationRegisterCache.vertexLife + \",\" + lifeTimeRegister + \".x\\n\";\n\t\t\t\t\t\tcode += \"max \" + tempTime + \",\" + accTime + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\t\t\t\tcode += \"min \" + tempTime + \",\" + tempTime + \",\" + lifeTimeRegister + \".y\\n\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 2:\n\t\t\t\t\t\tcode += \"sub \" + accTime + \",\" + accTime + \",\" + lifeTimeRegister + \".y\\n\";\n\t\t\t\t\t\tcode += \"max \" + tempTime + \",\" + accTime + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\t\t\t\tcode += \"min \" + tempTime + \",\" + tempTime + \",\" + lifeTimeRegister + \".z\\n\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 3:\n\t\t\t\t\t\tcode += \"sub \" + accTime + \",\" + accTime + \",\" + lifeTimeRegister + \".z\\n\";\n\t\t\t\t\t\tcode += \"max \" + tempTime + \",\" + accTime + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\t\t\t\tcode += \"min \" + tempTime + \",\" + tempTime + \",\" + lifeTimeRegister + \".w\\n\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\tif (this._iUsesMultiplier) {\n\t\t\t\t\tcode += \"mul \" + tempColor + \",\" + tempTime + \",\" + deltaMulValues[i] + \"\\n\";\n\t\t\t\t\tcode += \"add \" + accMultiplierColor + \",\" + accMultiplierColor + \",\" + tempColor + \"\\n\";\n\t\t\t\t}\n\t\t\t\tif (this._iUsesOffset) {\n\t\t\t\t\tcode += \"mul \" + tempColor + \",\" + tempTime + \",\" + deltaOffsetValues[i] + \"\\n\";\n\t\t\t\t\tcode += \"add \" + animationRegisterCache.colorAddTarget + \",\" + animationRegisterCache.colorAddTarget + \",\" + tempColor + \"\\n\";\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t//for the last segment:\n\t\t\tif (this._iNumSegmentPoint == 0)\n\t\t\t\ttempTime = animationRegisterCache.vertexLife;\n\t\t\telse {\n\t\t\t\tswitch (this._iNumSegmentPoint) {\n\t\t\t\t\tcase 1:\n\t\t\t\t\t\tcode += \"sub \" + accTime + \",\" + animationRegisterCache.vertexLife + \",\" + lifeTimeRegister + \".x\\n\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 2:\n\t\t\t\t\t\tcode += \"sub \" + accTime + \",\" + accTime + \",\" + lifeTimeRegister + \".y\\n\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 3:\n\t\t\t\t\t\tcode += \"sub \" + accTime + \",\" + accTime + \",\" + lifeTimeRegister + \".z\\n\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 4:\n\t\t\t\t\t\tcode += \"sub \" + accTime + \",\" + accTime + \",\" + lifeTimeRegister + \".w\\n\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\tcode += \"max \" + tempTime + \",\" + accTime + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\t\t}\n\t\t\tif (this._iUsesMultiplier) {\n\t\t\t\tcode += \"mul \" + tempColor + \",\" + tempTime + \",\" + deltaMulValues[this._iNumSegmentPoint] + \"\\n\";\n\t\t\t\tcode += \"add \" + accMultiplierColor + \",\" + accMultiplierColor + \",\" + tempColor + \"\\n\";\n\t\t\t\tcode += \"mul \" + animationRegisterCache.colorMulTarget + \",\" + animationRegisterCache.colorMulTarget + \",\" + accMultiplierColor + \"\\n\";\n\t\t\t}\n\t\t\tif (this._iUsesOffset) {\n\t\t\t\tcode += \"mul \" + tempColor + \",\" + tempTime + \",\" + deltaOffsetValues[this._iNumSegmentPoint] + \"\\n\";\n\t\t\t\tcode += \"add \" + animationRegisterCache.colorAddTarget + \",\" + animationRegisterCache.colorAddTarget + \",\" + tempColor + \"\\n\";\n\t\t\t}\n\n\t\t}\n\t\treturn code;\n\t}\n\n}\n\nexport = ParticleSegmentedColorNode;"]}
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleSegmentedColorNode.ts b/lib/animators/nodes/ParticleSegmentedColorNode.ts
new file mode 100644
index 000000000..edee40270
--- /dev/null
+++ b/lib/animators/nodes/ParticleSegmentedColorNode.ts
@@ -0,0 +1,186 @@
+import ColorTransform = require("awayjs-core/lib/core/geom/ColorTransform");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+
+import ParticleAnimationSet = require("awayjs-renderergl/lib/animators/ParticleAnimationSet");
+import ColorSegmentPoint = require("awayjs-renderergl/lib/animators/data/ColorSegmentPoint");
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleSegmentedColorState = require("awayjs-renderergl/lib/animators/states/ParticleSegmentedColorState");
+
+/**
+ *
+ */
+class ParticleSegmentedColorNode extends ParticleNodeBase
+{
+ /** @private */
+ public _iUsesMultiplier:boolean;
+ /** @private */
+ public _iUsesOffset:boolean;
+ /** @private */
+ public _iStartColor:ColorTransform;
+ /** @private */
+ public _iEndColor:ColorTransform;
+ /** @private */
+ public _iNumSegmentPoint:number /*int*/;
+ /** @private */
+ public _iSegmentPoints:Array;
+
+ constructor(usesMultiplier:boolean, usesOffset:boolean, numSegmentPoint:number /*int*/, startColor:ColorTransform, endColor:ColorTransform, segmentPoints:Array)
+ {
+ //because of the stage3d register limitation, it only support the global mode
+ super("ParticleSegmentedColor", ParticlePropertiesMode.GLOBAL, 0, ParticleAnimationSet.COLOR_PRIORITY);
+
+ this._pStateClass = ParticleSegmentedColorState;
+
+ if (numSegmentPoint > 4)
+ throw(new Error("the numSegmentPoint must be less or equal 4"));
+ this._iUsesMultiplier = usesMultiplier;
+ this._iUsesOffset = usesOffset;
+ this._iNumSegmentPoint = numSegmentPoint;
+ this._iStartColor = startColor;
+ this._iEndColor = endColor;
+ this._iSegmentPoints = segmentPoints;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iProcessAnimationSetting(particleAnimationSet:ParticleAnimationSet)
+ {
+ if (this._iUsesMultiplier)
+ particleAnimationSet.hasColorMulNode = true;
+ if (this._iUsesOffset)
+ particleAnimationSet.hasColorAddNode = true;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ var code:string = "";
+ if (animationRegisterCache.needFragmentAnimation) {
+ var accMultiplierColor:ShaderRegisterElement;
+ //var accOffsetColor:ShaderRegisterElement;
+ if (this._iUsesMultiplier) {
+ accMultiplierColor = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(accMultiplierColor, 1);
+ }
+
+ var tempColor:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ animationRegisterCache.addVertexTempUsages(tempColor, 1);
+
+ var temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ var accTime:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 0);
+ var tempTime:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 1);
+
+ if (this._iUsesMultiplier)
+ animationRegisterCache.removeVertexTempUsage(accMultiplierColor);
+
+ animationRegisterCache.removeVertexTempUsage(tempColor);
+
+ //for saving all the life values (at most 4)
+ var lifeTimeRegister:ShaderRegisterElement = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleSegmentedColorState.TIME_DATA_INDEX, lifeTimeRegister.index);
+
+ var i:number /*int*/;
+
+ var startMulValue:ShaderRegisterElement;
+ var deltaMulValues:Array;
+ if (this._iUsesMultiplier) {
+ startMulValue = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleSegmentedColorState.START_MULTIPLIER_INDEX, startMulValue.index);
+ deltaMulValues = new Array();
+ for (i = 0; i < this._iNumSegmentPoint + 1; i++)
+ deltaMulValues.push(animationRegisterCache.getFreeVertexConstant());
+ }
+
+ var startOffsetValue:ShaderRegisterElement;
+ var deltaOffsetValues:Array;
+ if (this._iUsesOffset) {
+ startOffsetValue = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleSegmentedColorState.START_OFFSET_INDEX, startOffsetValue.index);
+ deltaOffsetValues = new Array();
+ for (i = 0; i < this._iNumSegmentPoint + 1; i++)
+ deltaOffsetValues.push(animationRegisterCache.getFreeVertexConstant());
+ }
+
+ if (this._iUsesMultiplier)
+ code += "mov " + accMultiplierColor + "," + startMulValue + "\n";
+ if (this._iUsesOffset)
+ code += "add " + animationRegisterCache.colorAddTarget + "," + animationRegisterCache.colorAddTarget + "," + startOffsetValue + "\n";
+
+ for (i = 0; i < this._iNumSegmentPoint; i++) {
+ switch (i) {
+ case 0:
+ code += "min " + tempTime + "," + animationRegisterCache.vertexLife + "," + lifeTimeRegister + ".x\n";
+ break;
+ case 1:
+ code += "sub " + accTime + "," + animationRegisterCache.vertexLife + "," + lifeTimeRegister + ".x\n";
+ code += "max " + tempTime + "," + accTime + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "min " + tempTime + "," + tempTime + "," + lifeTimeRegister + ".y\n";
+ break;
+ case 2:
+ code += "sub " + accTime + "," + accTime + "," + lifeTimeRegister + ".y\n";
+ code += "max " + tempTime + "," + accTime + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "min " + tempTime + "," + tempTime + "," + lifeTimeRegister + ".z\n";
+ break;
+ case 3:
+ code += "sub " + accTime + "," + accTime + "," + lifeTimeRegister + ".z\n";
+ code += "max " + tempTime + "," + accTime + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "min " + tempTime + "," + tempTime + "," + lifeTimeRegister + ".w\n";
+ break;
+ }
+ if (this._iUsesMultiplier) {
+ code += "mul " + tempColor + "," + tempTime + "," + deltaMulValues[i] + "\n";
+ code += "add " + accMultiplierColor + "," + accMultiplierColor + "," + tempColor + "\n";
+ }
+ if (this._iUsesOffset) {
+ code += "mul " + tempColor + "," + tempTime + "," + deltaOffsetValues[i] + "\n";
+ code += "add " + animationRegisterCache.colorAddTarget + "," + animationRegisterCache.colorAddTarget + "," + tempColor + "\n";
+ }
+ }
+
+ //for the last segment:
+ if (this._iNumSegmentPoint == 0)
+ tempTime = animationRegisterCache.vertexLife;
+ else {
+ switch (this._iNumSegmentPoint) {
+ case 1:
+ code += "sub " + accTime + "," + animationRegisterCache.vertexLife + "," + lifeTimeRegister + ".x\n";
+ break;
+ case 2:
+ code += "sub " + accTime + "," + accTime + "," + lifeTimeRegister + ".y\n";
+ break;
+ case 3:
+ code += "sub " + accTime + "," + accTime + "," + lifeTimeRegister + ".z\n";
+ break;
+ case 4:
+ code += "sub " + accTime + "," + accTime + "," + lifeTimeRegister + ".w\n";
+ break;
+ }
+ code += "max " + tempTime + "," + accTime + "," + animationRegisterCache.vertexZeroConst + "\n";
+ }
+ if (this._iUsesMultiplier) {
+ code += "mul " + tempColor + "," + tempTime + "," + deltaMulValues[this._iNumSegmentPoint] + "\n";
+ code += "add " + accMultiplierColor + "," + accMultiplierColor + "," + tempColor + "\n";
+ code += "mul " + animationRegisterCache.colorMulTarget + "," + animationRegisterCache.colorMulTarget + "," + accMultiplierColor + "\n";
+ }
+ if (this._iUsesOffset) {
+ code += "mul " + tempColor + "," + tempTime + "," + deltaOffsetValues[this._iNumSegmentPoint] + "\n";
+ code += "add " + animationRegisterCache.colorAddTarget + "," + animationRegisterCache.colorAddTarget + "," + tempColor + "\n";
+ }
+
+ }
+ return code;
+ }
+
+}
+
+export = ParticleSegmentedColorNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleSpriteSheetNode.js b/lib/animators/nodes/ParticleSpriteSheetNode.js
new file mode 100755
index 000000000..be805ce67
--- /dev/null
+++ b/lib/animators/nodes/ParticleSpriteSheetNode.js
@@ -0,0 +1,167 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+var ParticleAnimationSet = require("awayjs-renderergl/lib/animators/ParticleAnimationSet");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+var ParticleSpriteSheetState = require("awayjs-renderergl/lib/animators/states/ParticleSpriteSheetState");
+/**
+ * A particle animation node used when a spritesheet texture is required to animate the particle.
+ * NB: to enable use of this node, the repeat
property on the material has to be set to true.
+ */
+var ParticleSpriteSheetNode = (function (_super) {
+ __extends(ParticleSpriteSheetNode, _super);
+ /**
+ * Creates a new ParticleSpriteSheetNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] numColumns Defines the number of columns in the spritesheet, when in global mode. Defaults to 1.
+ * @param [optional] numRows Defines the number of rows in the spritesheet, when in global mode. Defaults to 1.
+ * @param [optional] cycleDuration Defines the default cycle duration in seconds, when in global mode. Defaults to 1.
+ * @param [optional] cyclePhase Defines the default cycle phase, when in global mode. Defaults to 0.
+ * @param [optional] totalFrames Defines the total number of frames used by the spritesheet, when in global mode. Defaults to the number defined by numColumns and numRows.
+ * @param [optional] looping Defines whether the spritesheet animation is set to loop indefinitely. Defaults to true.
+ */
+ function ParticleSpriteSheetNode(mode /*uint*/, usesCycle, usesPhase, numColumns, numRows, cycleDuration, cyclePhase, totalFrames) {
+ if (numColumns === void 0) { numColumns = 1; }
+ if (numRows === void 0) { numRows = 1; }
+ if (cycleDuration === void 0) { cycleDuration = 1; }
+ if (cyclePhase === void 0) { cyclePhase = 0; }
+ if (totalFrames === void 0) { totalFrames = Number.MAX_VALUE; }
+ _super.call(this, "ParticleSpriteSheet", mode, usesCycle ? (usesPhase ? 3 : 2) : 1, ParticleAnimationSet.POST_PRIORITY + 1);
+ this._pStateClass = ParticleSpriteSheetState;
+ this._iUsesCycle = usesCycle;
+ this._iUsesPhase = usesPhase;
+ this._iNumColumns = numColumns;
+ this._iNumRows = numRows;
+ this._iCyclePhase = cyclePhase;
+ this._iCycleDuration = cycleDuration;
+ this._iTotalFrames = Math.min(totalFrames, numColumns * numRows);
+ }
+ Object.defineProperty(ParticleSpriteSheetNode.prototype, "numColumns", {
+ /**
+ * Defines the number of columns in the spritesheet, when in global mode. Defaults to 1. Read only.
+ */
+ get: function () {
+ return this._iNumColumns;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleSpriteSheetNode.prototype, "numRows", {
+ /**
+ * Defines the number of rows in the spritesheet, when in global mode. Defaults to 1. Read only.
+ */
+ get: function () {
+ return this._iNumRows;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleSpriteSheetNode.prototype, "totalFrames", {
+ /**
+ * Defines the total number of frames used by the spritesheet, when in global mode. Defaults to the number defined by numColumns and numRows. Read only.
+ */
+ get: function () {
+ return this._iTotalFrames;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ ParticleSpriteSheetNode.prototype.getAGALUVCode = function (shaderObject, animationRegisterCache) {
+ //get 2 vc
+ var uvParamConst1 = animationRegisterCache.getFreeVertexConstant();
+ var uvParamConst2 = (this._pMode == ParticlePropertiesMode.GLOBAL) ? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleSpriteSheetState.UV_INDEX_0, uvParamConst1.index);
+ animationRegisterCache.setRegisterIndex(this, ParticleSpriteSheetState.UV_INDEX_1, uvParamConst2.index);
+ var uTotal = new ShaderRegisterElement(uvParamConst1.regName, uvParamConst1.index, 0);
+ var uStep = new ShaderRegisterElement(uvParamConst1.regName, uvParamConst1.index, 1);
+ var vStep = new ShaderRegisterElement(uvParamConst1.regName, uvParamConst1.index, 2);
+ var uSpeed = new ShaderRegisterElement(uvParamConst2.regName, uvParamConst2.index, 0);
+ var cycle = new ShaderRegisterElement(uvParamConst2.regName, uvParamConst2.index, 1);
+ var phaseTime = new ShaderRegisterElement(uvParamConst2.regName, uvParamConst2.index, 2);
+ var temp = animationRegisterCache.getFreeVertexVectorTemp();
+ var time = new ShaderRegisterElement(temp.regName, temp.index, 0);
+ var vOffset = new ShaderRegisterElement(temp.regName, temp.index, 1);
+ temp = new ShaderRegisterElement(temp.regName, temp.index, 2);
+ var temp2 = new ShaderRegisterElement(temp.regName, temp.index, 3);
+ var u = new ShaderRegisterElement(animationRegisterCache.uvTarget.regName, animationRegisterCache.uvTarget.index, 0);
+ var v = new ShaderRegisterElement(animationRegisterCache.uvTarget.regName, animationRegisterCache.uvTarget.index, 1);
+ var code = "";
+ //scale uv
+ code += "mul " + u + "," + u + "," + uStep + "\n";
+ if (this._iNumRows > 1)
+ code += "mul " + v + "," + v + "," + vStep + "\n";
+ if (this._iUsesCycle) {
+ if (this._iUsesPhase)
+ code += "add " + time + "," + animationRegisterCache.vertexTime + "," + phaseTime + "\n";
+ else
+ code += "mov " + time + "," + animationRegisterCache.vertexTime + "\n";
+ code += "div " + time + "," + time + "," + cycle + "\n";
+ code += "frc " + time + "," + time + "\n";
+ code += "mul " + time + "," + time + "," + cycle + "\n";
+ code += "mul " + temp + "," + time + "," + uSpeed + "\n";
+ }
+ else
+ code += "mul " + temp.toString() + "," + animationRegisterCache.vertexLife + "," + uTotal + "\n";
+ if (this._iNumRows > 1) {
+ code += "frc " + temp2 + "," + temp + "\n";
+ code += "sub " + vOffset + "," + temp + "," + temp2 + "\n";
+ code += "mul " + vOffset + "," + vOffset + "," + vStep + "\n";
+ code += "add " + v + "," + v + "," + vOffset + "\n";
+ }
+ code += "div " + temp2 + "," + temp + "," + uStep + "\n";
+ code += "frc " + temp + "," + temp2 + "\n";
+ code += "sub " + temp2 + "," + temp2 + "," + temp + "\n";
+ code += "mul " + temp + "," + temp2 + "," + uStep + "\n";
+ if (this._iNumRows > 1)
+ code += "frc " + temp + "," + temp + "\n";
+ code += "add " + u + "," + u + "," + temp + "\n";
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleSpriteSheetNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleSpriteSheetNode.prototype._iProcessAnimationSetting = function (particleAnimationSet) {
+ particleAnimationSet.hasUVNode = true;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleSpriteSheetNode.prototype._iGeneratePropertyOfOneParticle = function (param) {
+ if (this._iUsesCycle) {
+ var uvCycle = param[ParticleSpriteSheetNode.UV_VECTOR3D];
+ if (!uvCycle)
+ throw (new Error("there is no " + ParticleSpriteSheetNode.UV_VECTOR3D + " in param!"));
+ if (uvCycle.x <= 0)
+ throw (new Error("the cycle duration must be greater than zero"));
+ var uTotal = this._iTotalFrames / this._iNumColumns;
+ this._pOneData[0] = uTotal / uvCycle.x;
+ this._pOneData[1] = uvCycle.x;
+ if (this._iUsesPhase)
+ this._pOneData[2] = uvCycle.y;
+ }
+ };
+ /**
+ * Reference for spritesheet node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
representing the cycleDuration (x), optional phaseTime (y).
+ */
+ ParticleSpriteSheetNode.UV_VECTOR3D = "UVVector3D";
+ return ParticleSpriteSheetNode;
+})(ParticleNodeBase);
+module.exports = ParticleSpriteSheetNode;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/nodes/particlespritesheetnode.ts"],"names":["ParticleSpriteSheetNode","ParticleSpriteSheetNode.constructor","ParticleSpriteSheetNode.numColumns","ParticleSpriteSheetNode.numRows","ParticleSpriteSheetNode.totalFrames","ParticleSpriteSheetNode.getAGALUVCode","ParticleSpriteSheetNode.getAnimationState","ParticleSpriteSheetNode._iProcessAnimationSetting","ParticleSpriteSheetNode._iGeneratePropertyOfOneParticle"],"mappings":"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","file":"animators/nodes/ParticleSpriteSheetNode.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\n\nimport ParticleAnimationSet\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimationSet\");\nimport ParticleProperties\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleProperties\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleNodeBase\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleNodeBase\");\nimport ParticleSpriteSheetState\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleSpriteSheetState\");\n\n/**\n * A particle animation node used when a spritesheet texture is required to animate the particle.\n * NB: to enable use of this node, the <code>repeat</code> property on the material has to be set to true.\n */\nclass ParticleSpriteSheetNode extends ParticleNodeBase\n{\n\t/** @private */\n\tpublic _iUsesCycle:boolean;\n\n\t/** @private */\n\tpublic _iUsesPhase:boolean;\n\n\t/** @private */\n\tpublic _iTotalFrames:number /*int*/;\n\t/** @private */\n\tpublic _iNumColumns:number /*int*/;\n\t/** @private */\n\tpublic _iNumRows:number /*int*/;\n\t/** @private */\n\tpublic _iCycleDuration:number;\n\t/** @private */\n\tpublic _iCyclePhase:number;\n\n\t/**\n\t * Reference for spritesheet node properties on a single particle (when in local property mode).\n\t * Expects a <code>Vector3D</code> representing the cycleDuration (x), optional phaseTime (y).\n\t */\n\tpublic static UV_VECTOR3D:string = \"UVVector3D\";\n\n\t/**\n\t * Defines the number of columns in the spritesheet, when in global mode. Defaults to 1. Read only.\n\t */\n\tpublic get numColumns():number\n\t{\n\t\treturn this._iNumColumns;\n\t}\n\n\t/**\n\t * Defines the number of rows in the spritesheet, when in global mode. Defaults to 1. Read only.\n\t */\n\tpublic get numRows():number\n\t{\n\t\treturn this._iNumRows;\n\t}\n\n\t/**\n\t * Defines the total number of frames used by the spritesheet, when in global mode. Defaults to the number defined by numColumns and numRows. Read only.\n\t */\n\tpublic get totalFrames():number\n\t{\n\t\treturn this._iTotalFrames;\n\t}\n\n\t/**\n\t * Creates a new <code>ParticleSpriteSheetNode</code>\n\t *\n\t * @param               mode            Defines whether the mode of operation acts on local properties of a particle or global properties of the node.\n\t * @param    [optional] numColumns      Defines the number of columns in the spritesheet, when in global mode. Defaults to 1.\n\t * @param    [optional] numRows         Defines the number of rows in the spritesheet, when in global mode. Defaults to 1.\n\t * @param    [optional] cycleDuration   Defines the default cycle duration in seconds, when in global mode. Defaults to 1.\n\t * @param    [optional] cyclePhase      Defines the default cycle phase, when in global mode. Defaults to 0.\n\t * @param    [optional] totalFrames     Defines the total number of frames used by the spritesheet, when in global mode. Defaults to the number defined by numColumns and numRows.\n\t * @param    [optional] looping         Defines whether the spritesheet animation is set to loop indefinitely. Defaults to true.\n\t */\n\tconstructor(mode:number /*uint*/, usesCycle:boolean, usesPhase:boolean, numColumns:number /*int*/ = 1, numRows:number /*uint*/ = 1, cycleDuration:number = 1, cyclePhase:number = 0, totalFrames:number /*uint*/ = Number.MAX_VALUE)\n\t{\n\t\tsuper(\"ParticleSpriteSheet\", mode, usesCycle? (usesPhase? 3 : 2) : 1, ParticleAnimationSet.POST_PRIORITY + 1);\n\n\t\tthis._pStateClass = ParticleSpriteSheetState;\n\n\t\tthis._iUsesCycle = usesCycle;\n\t\tthis._iUsesPhase = usesPhase;\n\n\t\tthis._iNumColumns = numColumns;\n\t\tthis._iNumRows = numRows;\n\t\tthis._iCyclePhase = cyclePhase;\n\t\tthis._iCycleDuration = cycleDuration;\n\t\tthis._iTotalFrames = Math.min(totalFrames, numColumns*numRows);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALUVCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string\n\t{\n\t\t//get 2 vc\n\t\tvar uvParamConst1:ShaderRegisterElement = animationRegisterCache.getFreeVertexConstant();\n\t\tvar uvParamConst2:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();\n\t\tanimationRegisterCache.setRegisterIndex(this, ParticleSpriteSheetState.UV_INDEX_0, uvParamConst1.index);\n\t\tanimationRegisterCache.setRegisterIndex(this, ParticleSpriteSheetState.UV_INDEX_1, uvParamConst2.index);\n\n\t\tvar uTotal:ShaderRegisterElement = new ShaderRegisterElement(uvParamConst1.regName, uvParamConst1.index, 0);\n\t\tvar uStep:ShaderRegisterElement = new ShaderRegisterElement(uvParamConst1.regName, uvParamConst1.index, 1);\n\t\tvar vStep:ShaderRegisterElement = new ShaderRegisterElement(uvParamConst1.regName, uvParamConst1.index, 2);\n\n\t\tvar uSpeed:ShaderRegisterElement = new ShaderRegisterElement(uvParamConst2.regName, uvParamConst2.index, 0);\n\t\tvar cycle:ShaderRegisterElement = new ShaderRegisterElement(uvParamConst2.regName, uvParamConst2.index, 1);\n\t\tvar phaseTime:ShaderRegisterElement = new ShaderRegisterElement(uvParamConst2.regName, uvParamConst2.index, 2);\n\n\t\tvar temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\tvar time:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 0);\n\t\tvar vOffset:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 1);\n\t\ttemp = new ShaderRegisterElement(temp.regName, temp.index, 2);\n\t\tvar temp2:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 3);\n\n\t\tvar u:ShaderRegisterElement = new ShaderRegisterElement(animationRegisterCache.uvTarget.regName, animationRegisterCache.uvTarget.index, 0);\n\t\tvar v:ShaderRegisterElement = new ShaderRegisterElement(animationRegisterCache.uvTarget.regName, animationRegisterCache.uvTarget.index, 1);\n\n\t\tvar code:string = \"\";\n\t\t//scale uv\n\t\tcode += \"mul \" + u + \",\" + u + \",\" + uStep + \"\\n\";\n\t\tif (this._iNumRows > 1)\n\t\t\tcode += \"mul \" + v + \",\" + v + \",\" + vStep + \"\\n\";\n\n\t\tif (this._iUsesCycle) {\n\t\t\tif (this._iUsesPhase)\n\t\t\t\tcode += \"add \" + time + \",\" + animationRegisterCache.vertexTime + \",\" + phaseTime + \"\\n\";\n\t\t\telse\n\t\t\t\tcode += \"mov \" + time + \",\" + animationRegisterCache.vertexTime + \"\\n\";\n\t\t\tcode += \"div \" + time + \",\" + time + \",\" + cycle + \"\\n\";\n\t\t\tcode += \"frc \" + time + \",\" + time + \"\\n\";\n\t\t\tcode += \"mul \" + time + \",\" + time + \",\" + cycle + \"\\n\";\n\t\t\tcode += \"mul \" + temp + \",\" + time + \",\" + uSpeed + \"\\n\";\n\t\t} else\n\t\t\tcode += \"mul \" + temp.toString() + \",\" + animationRegisterCache.vertexLife + \",\" + uTotal + \"\\n\";\n\n\t\tif (this._iNumRows > 1) {\n\t\t\tcode += \"frc \" + temp2 + \",\" + temp + \"\\n\";\n\t\t\tcode += \"sub \" + vOffset + \",\" + temp + \",\" + temp2 + \"\\n\";\n\t\t\tcode += \"mul \" + vOffset + \",\" + vOffset + \",\" + vStep + \"\\n\";\n\t\t\tcode += \"add \" + v + \",\" + v + \",\" + vOffset + \"\\n\";\n\t\t}\n\n\t\tcode += \"div \" + temp2 + \",\" + temp + \",\" + uStep + \"\\n\";\n\t\tcode += \"frc \" + temp + \",\" + temp2 + \"\\n\";\n\t\tcode += \"sub \" + temp2 + \",\" + temp2 + \",\" + temp + \"\\n\";\n\t\tcode += \"mul \" + temp + \",\" + temp2 + \",\" + uStep + \"\\n\";\n\n\t\tif (this._iNumRows > 1)\n\t\t\tcode += \"frc \" + temp + \",\" + temp + \"\\n\";\n\t\tcode += \"add \" + u + \",\" + u + \",\" + temp + \"\\n\";\n\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAnimationState(animator:AnimatorBase):ParticleSpriteSheetState\n\t{\n\t\treturn <ParticleSpriteSheetState> animator.getAnimationState(this);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _iProcessAnimationSetting(particleAnimationSet:ParticleAnimationSet)\n\t{\n\t\tparticleAnimationSet.hasUVNode = true;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _iGeneratePropertyOfOneParticle(param:ParticleProperties)\n\t{\n\t\tif (this._iUsesCycle) {\n\t\t\tvar uvCycle:Vector3D = param[ParticleSpriteSheetNode.UV_VECTOR3D];\n\t\t\tif (!uvCycle)\n\t\t\t\tthrow(new Error(\"there is no \" + ParticleSpriteSheetNode.UV_VECTOR3D + \" in param!\"));\n\t\t\tif (uvCycle.x <= 0)\n\t\t\t\tthrow(new Error(\"the cycle duration must be greater than zero\"));\n\t\t\tvar uTotal:number = this._iTotalFrames/this._iNumColumns;\n\t\t\tthis._pOneData[0] = uTotal/uvCycle.x;\n\t\t\tthis._pOneData[1] = uvCycle.x;\n\t\t\tif (this._iUsesPhase)\n\t\t\t\tthis._pOneData[2] = uvCycle.y;\n\t\t}\n\t}\n}\n\nexport = ParticleSpriteSheetNode;"]}
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleSpriteSheetNode.ts b/lib/animators/nodes/ParticleSpriteSheetNode.ts
new file mode 100644
index 000000000..d5b17daaf
--- /dev/null
+++ b/lib/animators/nodes/ParticleSpriteSheetNode.ts
@@ -0,0 +1,195 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+
+import ParticleAnimationSet = require("awayjs-renderergl/lib/animators/ParticleAnimationSet");
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleSpriteSheetState = require("awayjs-renderergl/lib/animators/states/ParticleSpriteSheetState");
+
+/**
+ * A particle animation node used when a spritesheet texture is required to animate the particle.
+ * NB: to enable use of this node, the repeat
property on the material has to be set to true.
+ */
+class ParticleSpriteSheetNode extends ParticleNodeBase
+{
+ /** @private */
+ public _iUsesCycle:boolean;
+
+ /** @private */
+ public _iUsesPhase:boolean;
+
+ /** @private */
+ public _iTotalFrames:number /*int*/;
+ /** @private */
+ public _iNumColumns:number /*int*/;
+ /** @private */
+ public _iNumRows:number /*int*/;
+ /** @private */
+ public _iCycleDuration:number;
+ /** @private */
+ public _iCyclePhase:number;
+
+ /**
+ * Reference for spritesheet node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
representing the cycleDuration (x), optional phaseTime (y).
+ */
+ public static UV_VECTOR3D:string = "UVVector3D";
+
+ /**
+ * Defines the number of columns in the spritesheet, when in global mode. Defaults to 1. Read only.
+ */
+ public get numColumns():number
+ {
+ return this._iNumColumns;
+ }
+
+ /**
+ * Defines the number of rows in the spritesheet, when in global mode. Defaults to 1. Read only.
+ */
+ public get numRows():number
+ {
+ return this._iNumRows;
+ }
+
+ /**
+ * Defines the total number of frames used by the spritesheet, when in global mode. Defaults to the number defined by numColumns and numRows. Read only.
+ */
+ public get totalFrames():number
+ {
+ return this._iTotalFrames;
+ }
+
+ /**
+ * Creates a new ParticleSpriteSheetNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] numColumns Defines the number of columns in the spritesheet, when in global mode. Defaults to 1.
+ * @param [optional] numRows Defines the number of rows in the spritesheet, when in global mode. Defaults to 1.
+ * @param [optional] cycleDuration Defines the default cycle duration in seconds, when in global mode. Defaults to 1.
+ * @param [optional] cyclePhase Defines the default cycle phase, when in global mode. Defaults to 0.
+ * @param [optional] totalFrames Defines the total number of frames used by the spritesheet, when in global mode. Defaults to the number defined by numColumns and numRows.
+ * @param [optional] looping Defines whether the spritesheet animation is set to loop indefinitely. Defaults to true.
+ */
+ constructor(mode:number /*uint*/, usesCycle:boolean, usesPhase:boolean, numColumns:number /*int*/ = 1, numRows:number /*uint*/ = 1, cycleDuration:number = 1, cyclePhase:number = 0, totalFrames:number /*uint*/ = Number.MAX_VALUE)
+ {
+ super("ParticleSpriteSheet", mode, usesCycle? (usesPhase? 3 : 2) : 1, ParticleAnimationSet.POST_PRIORITY + 1);
+
+ this._pStateClass = ParticleSpriteSheetState;
+
+ this._iUsesCycle = usesCycle;
+ this._iUsesPhase = usesPhase;
+
+ this._iNumColumns = numColumns;
+ this._iNumRows = numRows;
+ this._iCyclePhase = cyclePhase;
+ this._iCycleDuration = cycleDuration;
+ this._iTotalFrames = Math.min(totalFrames, numColumns*numRows);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALUVCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ //get 2 vc
+ var uvParamConst1:ShaderRegisterElement = animationRegisterCache.getFreeVertexConstant();
+ var uvParamConst2:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleSpriteSheetState.UV_INDEX_0, uvParamConst1.index);
+ animationRegisterCache.setRegisterIndex(this, ParticleSpriteSheetState.UV_INDEX_1, uvParamConst2.index);
+
+ var uTotal:ShaderRegisterElement = new ShaderRegisterElement(uvParamConst1.regName, uvParamConst1.index, 0);
+ var uStep:ShaderRegisterElement = new ShaderRegisterElement(uvParamConst1.regName, uvParamConst1.index, 1);
+ var vStep:ShaderRegisterElement = new ShaderRegisterElement(uvParamConst1.regName, uvParamConst1.index, 2);
+
+ var uSpeed:ShaderRegisterElement = new ShaderRegisterElement(uvParamConst2.regName, uvParamConst2.index, 0);
+ var cycle:ShaderRegisterElement = new ShaderRegisterElement(uvParamConst2.regName, uvParamConst2.index, 1);
+ var phaseTime:ShaderRegisterElement = new ShaderRegisterElement(uvParamConst2.regName, uvParamConst2.index, 2);
+
+ var temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ var time:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 0);
+ var vOffset:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 1);
+ temp = new ShaderRegisterElement(temp.regName, temp.index, 2);
+ var temp2:ShaderRegisterElement = new ShaderRegisterElement(temp.regName, temp.index, 3);
+
+ var u:ShaderRegisterElement = new ShaderRegisterElement(animationRegisterCache.uvTarget.regName, animationRegisterCache.uvTarget.index, 0);
+ var v:ShaderRegisterElement = new ShaderRegisterElement(animationRegisterCache.uvTarget.regName, animationRegisterCache.uvTarget.index, 1);
+
+ var code:string = "";
+ //scale uv
+ code += "mul " + u + "," + u + "," + uStep + "\n";
+ if (this._iNumRows > 1)
+ code += "mul " + v + "," + v + "," + vStep + "\n";
+
+ if (this._iUsesCycle) {
+ if (this._iUsesPhase)
+ code += "add " + time + "," + animationRegisterCache.vertexTime + "," + phaseTime + "\n";
+ else
+ code += "mov " + time + "," + animationRegisterCache.vertexTime + "\n";
+ code += "div " + time + "," + time + "," + cycle + "\n";
+ code += "frc " + time + "," + time + "\n";
+ code += "mul " + time + "," + time + "," + cycle + "\n";
+ code += "mul " + temp + "," + time + "," + uSpeed + "\n";
+ } else
+ code += "mul " + temp.toString() + "," + animationRegisterCache.vertexLife + "," + uTotal + "\n";
+
+ if (this._iNumRows > 1) {
+ code += "frc " + temp2 + "," + temp + "\n";
+ code += "sub " + vOffset + "," + temp + "," + temp2 + "\n";
+ code += "mul " + vOffset + "," + vOffset + "," + vStep + "\n";
+ code += "add " + v + "," + v + "," + vOffset + "\n";
+ }
+
+ code += "div " + temp2 + "," + temp + "," + uStep + "\n";
+ code += "frc " + temp + "," + temp2 + "\n";
+ code += "sub " + temp2 + "," + temp2 + "," + temp + "\n";
+ code += "mul " + temp + "," + temp2 + "," + uStep + "\n";
+
+ if (this._iNumRows > 1)
+ code += "frc " + temp + "," + temp + "\n";
+ code += "add " + u + "," + u + "," + temp + "\n";
+
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):ParticleSpriteSheetState
+ {
+ return animator.getAnimationState(this);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iProcessAnimationSetting(particleAnimationSet:ParticleAnimationSet)
+ {
+ particleAnimationSet.hasUVNode = true;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iGeneratePropertyOfOneParticle(param:ParticleProperties)
+ {
+ if (this._iUsesCycle) {
+ var uvCycle:Vector3D = param[ParticleSpriteSheetNode.UV_VECTOR3D];
+ if (!uvCycle)
+ throw(new Error("there is no " + ParticleSpriteSheetNode.UV_VECTOR3D + " in param!"));
+ if (uvCycle.x <= 0)
+ throw(new Error("the cycle duration must be greater than zero"));
+ var uTotal:number = this._iTotalFrames/this._iNumColumns;
+ this._pOneData[0] = uTotal/uvCycle.x;
+ this._pOneData[1] = uvCycle.x;
+ if (this._iUsesPhase)
+ this._pOneData[2] = uvCycle.y;
+ }
+ }
+}
+
+export = ParticleSpriteSheetNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleTimeNode.js b/lib/animators/nodes/ParticleTimeNode.js
new file mode 100755
index 000000000..f19efe244
--- /dev/null
+++ b/lib/animators/nodes/ParticleTimeNode.js
@@ -0,0 +1,90 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+var ParticleTimeState = require("awayjs-renderergl/lib/animators/states/ParticleTimeState");
+/**
+ * A particle animation node used as the base node for timekeeping inside a particle. Automatically added to a particle animation set on instatiation.
+ */
+var ParticleTimeNode = (function (_super) {
+ __extends(ParticleTimeNode, _super);
+ /**
+ * Creates a new ParticleTimeNode
+ *
+ * @param [optional] usesDuration Defines whether the node uses the duration
data in the static properties to determine how long a particle is visible for. Defaults to false.
+ * @param [optional] usesDelay Defines whether the node uses the delay
data in the static properties to determine how long a particle is hidden for. Defaults to false. Requires usesDuration
to be true.
+ * @param [optional] usesLooping Defines whether the node creates a looping timeframe for each particle determined by the startTime
, duration
and delay
data in the static properties function. Defaults to false. Requires usesLooping
to be true.
+ */
+ function ParticleTimeNode(usesDuration, usesLooping, usesDelay) {
+ if (usesDuration === void 0) { usesDuration = false; }
+ if (usesLooping === void 0) { usesLooping = false; }
+ if (usesDelay === void 0) { usesDelay = false; }
+ this._pStateClass = ParticleTimeState;
+ this._iUsesDuration = usesDuration;
+ this._iUsesLooping = usesLooping;
+ this._iUsesDelay = usesDelay;
+ _super.call(this, "ParticleTime", ParticlePropertiesMode.LOCAL_STATIC, 4, 0);
+ }
+ /**
+ * @inheritDoc
+ */
+ ParticleTimeNode.prototype.getAGALVertexCode = function (shaderObject, animationRegisterCache) {
+ var timeStreamRegister = animationRegisterCache.getFreeVertexAttribute(); //timeStreamRegister.x is start,timeStreamRegister.y is during time
+ animationRegisterCache.setRegisterIndex(this, ParticleTimeState.TIME_STREAM_INDEX, timeStreamRegister.index);
+ var timeConst = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleTimeState.TIME_CONSTANT_INDEX, timeConst.index);
+ var code = "";
+ code += "sub " + animationRegisterCache.vertexTime + "," + timeConst + "," + timeStreamRegister + ".x\n";
+ //if time=0,set the position to zero.
+ var temp = animationRegisterCache.getFreeVertexSingleTemp();
+ code += "sge " + temp + "," + animationRegisterCache.vertexTime + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mul " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz," + temp + "\n";
+ if (this._iUsesDuration) {
+ if (this._iUsesLooping) {
+ var div = animationRegisterCache.getFreeVertexSingleTemp();
+ if (this._iUsesDelay) {
+ code += "div " + div + "," + animationRegisterCache.vertexTime + "," + timeStreamRegister + ".z\n";
+ code += "frc " + div + "," + div + "\n";
+ code += "mul " + animationRegisterCache.vertexTime + "," + div + "," + timeStreamRegister + ".z\n";
+ code += "slt " + div + "," + animationRegisterCache.vertexTime + "," + timeStreamRegister + ".y\n";
+ code += "mul " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz," + div + "\n";
+ }
+ else {
+ code += "mul " + div + "," + animationRegisterCache.vertexTime + "," + timeStreamRegister + ".w\n";
+ code += "frc " + div + "," + div + "\n";
+ code += "mul " + animationRegisterCache.vertexTime + "," + div + "," + timeStreamRegister + ".y\n";
+ }
+ }
+ else {
+ var sge = animationRegisterCache.getFreeVertexSingleTemp();
+ code += "sge " + sge + "," + timeStreamRegister + ".y," + animationRegisterCache.vertexTime + "\n";
+ code += "mul " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz," + sge + "\n";
+ }
+ }
+ code += "mul " + animationRegisterCache.vertexLife + "," + animationRegisterCache.vertexTime + "," + timeStreamRegister + ".w\n";
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleTimeNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleTimeNode.prototype._iGeneratePropertyOfOneParticle = function (param) {
+ this._pOneData[0] = param.startTime;
+ this._pOneData[1] = param.duration;
+ this._pOneData[2] = param.delay + param.duration;
+ this._pOneData[3] = 1 / param.duration;
+ };
+ return ParticleTimeNode;
+})(ParticleNodeBase);
+module.exports = ParticleTimeNode;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/nodes/particletimenode.ts"],"names":["ParticleTimeNode","ParticleTimeNode.constructor","ParticleTimeNode.getAGALVertexCode","ParticleTimeNode.getAnimationState","ParticleTimeNode._iGeneratePropertyOfOneParticle"],"mappings":"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","file":"animators/nodes/ParticleTimeNode.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\n\nimport ParticleProperties\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleProperties\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleNodeBase\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleNodeBase\");\nimport ParticleTimeState\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleTimeState\");\n\n/**\n * A particle animation node used as the base node for timekeeping inside a particle. Automatically added to a particle animation set on instatiation.\n */\nclass ParticleTimeNode extends ParticleNodeBase\n{\n\t/** @private */\n\tpublic _iUsesDuration:boolean;\n\t/** @private */\n\tpublic _iUsesDelay:boolean;\n\t/** @private */\n\tpublic _iUsesLooping:boolean;\n\n\t/**\n\t * Creates a new <code>ParticleTimeNode</code>\n\t *\n\t * @param    [optional] usesDuration    Defines whether the node uses the <code>duration</code> data in the static properties to determine how long a particle is visible for. Defaults to false.\n\t * @param    [optional] usesDelay       Defines whether the node uses the <code>delay</code> data in the static properties to determine how long a particle is hidden for. Defaults to false. Requires <code>usesDuration</code> to be true.\n\t * @param    [optional] usesLooping     Defines whether the node creates a looping timeframe for each particle determined by the <code>startTime</code>, <code>duration</code> and <code>delay</code> data in the static properties function. Defaults to false. Requires <code>usesLooping</code> to be true.\n\t */\n\tconstructor(usesDuration:boolean = false, usesLooping:boolean = false, usesDelay:boolean = false)\n\t{\n\t\tthis._pStateClass = ParticleTimeState;\n\n\t\tthis._iUsesDuration = usesDuration;\n\t\tthis._iUsesLooping = usesLooping;\n\t\tthis._iUsesDelay = usesDelay;\n\n\t\tsuper(\"ParticleTime\", ParticlePropertiesMode.LOCAL_STATIC, 4, 0);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string\n\t{\n\t\tvar timeStreamRegister:ShaderRegisterElement = animationRegisterCache.getFreeVertexAttribute(); //timeStreamRegister.x is start，timeStreamRegister.y is during time\n\t\tanimationRegisterCache.setRegisterIndex(this, ParticleTimeState.TIME_STREAM_INDEX, timeStreamRegister.index);\n\t\tvar timeConst:ShaderRegisterElement = animationRegisterCache.getFreeVertexConstant();\n\t\tanimationRegisterCache.setRegisterIndex(this, ParticleTimeState.TIME_CONSTANT_INDEX, timeConst.index);\n\n\t\tvar code:string = \"\";\n\t\tcode += \"sub \" + animationRegisterCache.vertexTime + \",\" + timeConst + \",\" + timeStreamRegister + \".x\\n\";\n\t\t//if time=0,set the position to zero.\n\t\tvar temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexSingleTemp();\n\t\tcode += \"sge \" + temp + \",\" + animationRegisterCache.vertexTime + \",\" + animationRegisterCache.vertexZeroConst + \"\\n\";\n\t\tcode += \"mul \" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + temp + \"\\n\";\n\t\tif (this._iUsesDuration) {\n\t\t\tif (this._iUsesLooping) {\n\t\t\t\tvar div:ShaderRegisterElement = animationRegisterCache.getFreeVertexSingleTemp();\n\t\t\t\tif (this._iUsesDelay) {\n\t\t\t\t\tcode += \"div \" + div + \",\" + animationRegisterCache.vertexTime + \",\" + timeStreamRegister + \".z\\n\";\n\t\t\t\t\tcode += \"frc \" + div + \",\" + div + \"\\n\";\n\t\t\t\t\tcode += \"mul \" + animationRegisterCache.vertexTime + \",\" + div + \",\" + timeStreamRegister + \".z\\n\";\n\t\t\t\t\tcode += \"slt \" + div + \",\" + animationRegisterCache.vertexTime + \",\" + timeStreamRegister + \".y\\n\";\n\t\t\t\t\tcode += \"mul \" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + div + \"\\n\";\n\t\t\t\t} else {\n\t\t\t\t\tcode += \"mul \" + div + \",\" + animationRegisterCache.vertexTime + \",\" + timeStreamRegister + \".w\\n\";\n\t\t\t\t\tcode += \"frc \" + div + \",\" + div + \"\\n\";\n\t\t\t\t\tcode += \"mul \" + animationRegisterCache.vertexTime + \",\" + div + \",\" + timeStreamRegister + \".y\\n\";\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tvar sge:ShaderRegisterElement = animationRegisterCache.getFreeVertexSingleTemp();\n\t\t\t\tcode += \"sge \" + sge + \",\" + timeStreamRegister + \".y,\" + animationRegisterCache.vertexTime + \"\\n\";\n\t\t\t\tcode += \"mul \" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + animationRegisterCache.scaleAndRotateTarget + \".xyz,\" + sge + \"\\n\";\n\t\t\t}\n\t\t}\n\t\tcode += \"mul \" + animationRegisterCache.vertexLife + \",\" + animationRegisterCache.vertexTime + \",\" + timeStreamRegister + \".w\\n\";\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAnimationState(animator:AnimatorBase):ParticleTimeState\n\t{\n\t\treturn <ParticleTimeState> animator.getAnimationState(this);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _iGeneratePropertyOfOneParticle(param:ParticleProperties)\n\t{\n\t\tthis._pOneData[0] = param.startTime;\n\t\tthis._pOneData[1] = param.duration;\n\t\tthis._pOneData[2] = param.delay + param.duration;\n\t\tthis._pOneData[3] = 1/param.duration;\n\n\t}\n}\n\nexport = ParticleTimeNode;"]}
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleTimeNode.ts b/lib/animators/nodes/ParticleTimeNode.ts
new file mode 100644
index 000000000..2a63b1f06
--- /dev/null
+++ b/lib/animators/nodes/ParticleTimeNode.ts
@@ -0,0 +1,104 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleTimeState = require("awayjs-renderergl/lib/animators/states/ParticleTimeState");
+
+/**
+ * A particle animation node used as the base node for timekeeping inside a particle. Automatically added to a particle animation set on instatiation.
+ */
+class ParticleTimeNode extends ParticleNodeBase
+{
+ /** @private */
+ public _iUsesDuration:boolean;
+ /** @private */
+ public _iUsesDelay:boolean;
+ /** @private */
+ public _iUsesLooping:boolean;
+
+ /**
+ * Creates a new ParticleTimeNode
+ *
+ * @param [optional] usesDuration Defines whether the node uses the duration
data in the static properties to determine how long a particle is visible for. Defaults to false.
+ * @param [optional] usesDelay Defines whether the node uses the delay
data in the static properties to determine how long a particle is hidden for. Defaults to false. Requires usesDuration
to be true.
+ * @param [optional] usesLooping Defines whether the node creates a looping timeframe for each particle determined by the startTime
, duration
and delay
data in the static properties function. Defaults to false. Requires usesLooping
to be true.
+ */
+ constructor(usesDuration:boolean = false, usesLooping:boolean = false, usesDelay:boolean = false)
+ {
+ this._pStateClass = ParticleTimeState;
+
+ this._iUsesDuration = usesDuration;
+ this._iUsesLooping = usesLooping;
+ this._iUsesDelay = usesDelay;
+
+ super("ParticleTime", ParticlePropertiesMode.LOCAL_STATIC, 4, 0);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ var timeStreamRegister:ShaderRegisterElement = animationRegisterCache.getFreeVertexAttribute(); //timeStreamRegister.x is start,timeStreamRegister.y is during time
+ animationRegisterCache.setRegisterIndex(this, ParticleTimeState.TIME_STREAM_INDEX, timeStreamRegister.index);
+ var timeConst:ShaderRegisterElement = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleTimeState.TIME_CONSTANT_INDEX, timeConst.index);
+
+ var code:string = "";
+ code += "sub " + animationRegisterCache.vertexTime + "," + timeConst + "," + timeStreamRegister + ".x\n";
+ //if time=0,set the position to zero.
+ var temp:ShaderRegisterElement = animationRegisterCache.getFreeVertexSingleTemp();
+ code += "sge " + temp + "," + animationRegisterCache.vertexTime + "," + animationRegisterCache.vertexZeroConst + "\n";
+ code += "mul " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz," + temp + "\n";
+ if (this._iUsesDuration) {
+ if (this._iUsesLooping) {
+ var div:ShaderRegisterElement = animationRegisterCache.getFreeVertexSingleTemp();
+ if (this._iUsesDelay) {
+ code += "div " + div + "," + animationRegisterCache.vertexTime + "," + timeStreamRegister + ".z\n";
+ code += "frc " + div + "," + div + "\n";
+ code += "mul " + animationRegisterCache.vertexTime + "," + div + "," + timeStreamRegister + ".z\n";
+ code += "slt " + div + "," + animationRegisterCache.vertexTime + "," + timeStreamRegister + ".y\n";
+ code += "mul " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz," + div + "\n";
+ } else {
+ code += "mul " + div + "," + animationRegisterCache.vertexTime + "," + timeStreamRegister + ".w\n";
+ code += "frc " + div + "," + div + "\n";
+ code += "mul " + animationRegisterCache.vertexTime + "," + div + "," + timeStreamRegister + ".y\n";
+ }
+ } else {
+ var sge:ShaderRegisterElement = animationRegisterCache.getFreeVertexSingleTemp();
+ code += "sge " + sge + "," + timeStreamRegister + ".y," + animationRegisterCache.vertexTime + "\n";
+ code += "mul " + animationRegisterCache.scaleAndRotateTarget + ".xyz," + animationRegisterCache.scaleAndRotateTarget + ".xyz," + sge + "\n";
+ }
+ }
+ code += "mul " + animationRegisterCache.vertexLife + "," + animationRegisterCache.vertexTime + "," + timeStreamRegister + ".w\n";
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):ParticleTimeState
+ {
+ return animator.getAnimationState(this);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iGeneratePropertyOfOneParticle(param:ParticleProperties)
+ {
+ this._pOneData[0] = param.startTime;
+ this._pOneData[1] = param.duration;
+ this._pOneData[2] = param.delay + param.duration;
+ this._pOneData[3] = 1/param.duration;
+
+ }
+}
+
+export = ParticleTimeNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleUVNode.js b/lib/animators/nodes/ParticleUVNode.js
new file mode 100755
index 000000000..681c1a2c2
--- /dev/null
+++ b/lib/animators/nodes/ParticleUVNode.js
@@ -0,0 +1,123 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+var ParticleAnimationSet = require("awayjs-renderergl/lib/animators/ParticleAnimationSet");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+var ParticleUVState = require("awayjs-renderergl/lib/animators/states/ParticleUVState");
+/**
+ * A particle animation node used to control the UV offset and scale of a particle over time.
+ */
+var ParticleUVNode = (function (_super) {
+ __extends(ParticleUVNode, _super);
+ /**
+ * Creates a new ParticleTimeNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] cycle Defines whether the time track is in loop mode. Defaults to false.
+ * @param [optional] scale Defines whether the time track is in loop mode. Defaults to false.
+ * @param [optional] axis Defines whether the time track is in loop mode. Defaults to false.
+ */
+ function ParticleUVNode(mode /*uint*/, cycle, scale, axis) {
+ if (cycle === void 0) { cycle = 1; }
+ if (scale === void 0) { scale = 1; }
+ if (axis === void 0) { axis = "x"; }
+ //because of the stage3d register limitation, it only support the global mode
+ _super.call(this, "ParticleUV", ParticlePropertiesMode.GLOBAL, 4, ParticleAnimationSet.POST_PRIORITY + 1);
+ this._pStateClass = ParticleUVState;
+ this._cycle = cycle;
+ this._scale = scale;
+ this._axis = axis;
+ this.updateUVData();
+ }
+ Object.defineProperty(ParticleUVNode.prototype, "cycle", {
+ /**
+ *
+ */
+ get: function () {
+ return this._cycle;
+ },
+ set: function (value) {
+ this._cycle = value;
+ this.updateUVData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleUVNode.prototype, "scale", {
+ /**
+ *
+ */
+ get: function () {
+ return this._scale;
+ },
+ set: function (value) {
+ this._scale = value;
+ this.updateUVData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleUVNode.prototype, "axis", {
+ /**
+ *
+ */
+ get: function () {
+ return this._axis;
+ },
+ set: function (value) {
+ this._axis = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ ParticleUVNode.prototype.getAGALUVCode = function (shaderObject, animationRegisterCache) {
+ var code = "";
+ var uvConst = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleUVState.UV_INDEX, uvConst.index);
+ var axisIndex = this._axis == "x" ? 0 : (this._axis == "y" ? 1 : 2);
+ var target = new ShaderRegisterElement(animationRegisterCache.uvTarget.regName, animationRegisterCache.uvTarget.index, axisIndex);
+ var sin = animationRegisterCache.getFreeVertexSingleTemp();
+ if (this._scale != 1)
+ code += "mul " + target + "," + target + "," + uvConst + ".y\n";
+ code += "mul " + sin + "," + animationRegisterCache.vertexTime + "," + uvConst + ".x\n";
+ code += "sin " + sin + "," + sin + "\n";
+ code += "add " + target + "," + target + "," + sin + "\n";
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleUVNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ ParticleUVNode.prototype.updateUVData = function () {
+ this._iUvData = new Vector3D(Math.PI * 2 / this._cycle, this._scale, 0, 0);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleUVNode.prototype._iProcessAnimationSetting = function (particleAnimationSet) {
+ particleAnimationSet.hasUVNode = true;
+ };
+ /**
+ *
+ */
+ ParticleUVNode.U_AXIS = "x";
+ /**
+ *
+ */
+ ParticleUVNode.V_AXIS = "y";
+ return ParticleUVNode;
+})(ParticleNodeBase);
+module.exports = ParticleUVNode;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/nodes/particleuvnode.ts"],"names":["ParticleUVNode","ParticleUVNode.constructor","ParticleUVNode.cycle","ParticleUVNode.scale","ParticleUVNode.axis","ParticleUVNode.getAGALUVCode","ParticleUVNode.getAnimationState","ParticleUVNode.updateUVData","ParticleUVNode._iProcessAnimationSetting"],"mappings":"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","file":"animators/nodes/ParticleUVNode.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\n\nimport ParticleAnimationSet\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimationSet\");\nimport ParticleProperties\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleProperties\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleNodeBase\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleNodeBase\");\nimport ParticleUVState\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleUVState\");\n\n/**\n * A particle animation node used to control the UV offset and scale of a particle over time.\n */\nclass ParticleUVNode extends ParticleNodeBase\n{\n\t/** @private */\n\tpublic _iUvData:Vector3D;\n\n\t/**\n\t *\n\t */\n\tpublic static U_AXIS:string = \"x\";\n\n\t/**\n\t *\n\t */\n\tpublic static V_AXIS:string = \"y\";\n\n\tprivate _cycle:number;\n\tprivate _scale:number;\n\tprivate _axis:string;\n\n\t/**\n\t * Creates a new <code>ParticleTimeNode</code>\n\t *\n\t * @param               mode            Defines whether the mode of operation acts on local properties of a particle or global properties of the node.\n\t * @param    [optional] cycle           Defines whether the time track is in loop mode. Defaults to false.\n\t * @param    [optional] scale           Defines whether the time track is in loop mode. Defaults to false.\n\t * @param    [optional] axis            Defines whether the time track is in loop mode. Defaults to false.\n\t */\n\tconstructor(mode:number /*uint*/, cycle:number = 1, scale:number = 1, axis:string = \"x\")\n\t{\n\t\t//because of the stage3d register limitation, it only support the global mode\n\t\tsuper(\"ParticleUV\", ParticlePropertiesMode.GLOBAL, 4, ParticleAnimationSet.POST_PRIORITY + 1);\n\n\t\tthis._pStateClass = ParticleUVState;\n\n\t\tthis._cycle = cycle;\n\t\tthis._scale = scale;\n\t\tthis._axis = axis;\n\n\t\tthis.updateUVData();\n\t}\n\n\t/**\n\t *\n\t */\n\tpublic get cycle():number\n\t{\n\t\treturn this._cycle;\n\t}\n\n\tpublic set cycle(value:number)\n\t{\n\t\tthis._cycle = value;\n\n\t\tthis.updateUVData();\n\t}\n\n\t/**\n\t *\n\t */\n\tpublic get scale():number\n\t{\n\t\treturn this._scale;\n\t}\n\n\tpublic set scale(value:number)\n\t{\n\t\tthis._scale = value;\n\n\t\tthis.updateUVData();\n\t}\n\n\t/**\n\t *\n\t */\n\tpublic get axis():string\n\t{\n\t\treturn this._axis;\n\t}\n\n\tpublic set axis(value:string)\n\t{\n\t\tthis._axis = value;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALUVCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string\n\t{\n\t\tvar code:string = \"\";\n\n\t\tvar uvConst:ShaderRegisterElement = animationRegisterCache.getFreeVertexConstant();\n\t\tanimationRegisterCache.setRegisterIndex(this, ParticleUVState.UV_INDEX, uvConst.index);\n\n\t\tvar axisIndex:number = this._axis == \"x\"? 0 : (this._axis == \"y\"? 1 : 2);\n\n\t\tvar target:ShaderRegisterElement = new ShaderRegisterElement(animationRegisterCache.uvTarget.regName, animationRegisterCache.uvTarget.index, axisIndex);\n\n\t\tvar sin:ShaderRegisterElement = animationRegisterCache.getFreeVertexSingleTemp();\n\n\t\tif (this._scale != 1)\n\t\t\tcode += \"mul \" + target + \",\" + target + \",\" + uvConst + \".y\\n\";\n\n\t\tcode += \"mul \" + sin + \",\" + animationRegisterCache.vertexTime + \",\" + uvConst + \".x\\n\";\n\t\tcode += \"sin \" + sin + \",\" + sin + \"\\n\";\n\t\tcode += \"add \" + target + \",\" + target + \",\" + sin + \"\\n\";\n\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAnimationState(animator:AnimatorBase):ParticleUVState\n\t{\n\t\treturn <ParticleUVState> animator.getAnimationState(this);\n\t}\n\n\tprivate updateUVData()\n\t{\n\t\tthis._iUvData = new Vector3D(Math.PI*2/this._cycle, this._scale, 0, 0);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _iProcessAnimationSetting(particleAnimationSet:ParticleAnimationSet)\n\t{\n\t\tparticleAnimationSet.hasUVNode = true;\n\t}\n}\n\nexport = ParticleUVNode;"]}
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleUVNode.ts b/lib/animators/nodes/ParticleUVNode.ts
new file mode 100644
index 000000000..46064b972
--- /dev/null
+++ b/lib/animators/nodes/ParticleUVNode.ts
@@ -0,0 +1,149 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+
+import ParticleAnimationSet = require("awayjs-renderergl/lib/animators/ParticleAnimationSet");
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleUVState = require("awayjs-renderergl/lib/animators/states/ParticleUVState");
+
+/**
+ * A particle animation node used to control the UV offset and scale of a particle over time.
+ */
+class ParticleUVNode extends ParticleNodeBase
+{
+ /** @private */
+ public _iUvData:Vector3D;
+
+ /**
+ *
+ */
+ public static U_AXIS:string = "x";
+
+ /**
+ *
+ */
+ public static V_AXIS:string = "y";
+
+ private _cycle:number;
+ private _scale:number;
+ private _axis:string;
+
+ /**
+ * Creates a new ParticleTimeNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] cycle Defines whether the time track is in loop mode. Defaults to false.
+ * @param [optional] scale Defines whether the time track is in loop mode. Defaults to false.
+ * @param [optional] axis Defines whether the time track is in loop mode. Defaults to false.
+ */
+ constructor(mode:number /*uint*/, cycle:number = 1, scale:number = 1, axis:string = "x")
+ {
+ //because of the stage3d register limitation, it only support the global mode
+ super("ParticleUV", ParticlePropertiesMode.GLOBAL, 4, ParticleAnimationSet.POST_PRIORITY + 1);
+
+ this._pStateClass = ParticleUVState;
+
+ this._cycle = cycle;
+ this._scale = scale;
+ this._axis = axis;
+
+ this.updateUVData();
+ }
+
+ /**
+ *
+ */
+ public get cycle():number
+ {
+ return this._cycle;
+ }
+
+ public set cycle(value:number)
+ {
+ this._cycle = value;
+
+ this.updateUVData();
+ }
+
+ /**
+ *
+ */
+ public get scale():number
+ {
+ return this._scale;
+ }
+
+ public set scale(value:number)
+ {
+ this._scale = value;
+
+ this.updateUVData();
+ }
+
+ /**
+ *
+ */
+ public get axis():string
+ {
+ return this._axis;
+ }
+
+ public set axis(value:string)
+ {
+ this._axis = value;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALUVCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ var code:string = "";
+
+ var uvConst:ShaderRegisterElement = animationRegisterCache.getFreeVertexConstant();
+ animationRegisterCache.setRegisterIndex(this, ParticleUVState.UV_INDEX, uvConst.index);
+
+ var axisIndex:number = this._axis == "x"? 0 : (this._axis == "y"? 1 : 2);
+
+ var target:ShaderRegisterElement = new ShaderRegisterElement(animationRegisterCache.uvTarget.regName, animationRegisterCache.uvTarget.index, axisIndex);
+
+ var sin:ShaderRegisterElement = animationRegisterCache.getFreeVertexSingleTemp();
+
+ if (this._scale != 1)
+ code += "mul " + target + "," + target + "," + uvConst + ".y\n";
+
+ code += "mul " + sin + "," + animationRegisterCache.vertexTime + "," + uvConst + ".x\n";
+ code += "sin " + sin + "," + sin + "\n";
+ code += "add " + target + "," + target + "," + sin + "\n";
+
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):ParticleUVState
+ {
+ return animator.getAnimationState(this);
+ }
+
+ private updateUVData()
+ {
+ this._iUvData = new Vector3D(Math.PI*2/this._cycle, this._scale, 0, 0);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iProcessAnimationSetting(particleAnimationSet:ParticleAnimationSet)
+ {
+ particleAnimationSet.hasUVNode = true;
+ }
+}
+
+export = ParticleUVNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleVelocityNode.js b/lib/animators/nodes/ParticleVelocityNode.js
new file mode 100755
index 000000000..68ae3dad7
--- /dev/null
+++ b/lib/animators/nodes/ParticleVelocityNode.js
@@ -0,0 +1,68 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+var ParticleVelocityState = require("awayjs-renderergl/lib/animators/states/ParticleVelocityState");
+/**
+ * A particle animation node used to set the starting velocity of a particle.
+ */
+var ParticleVelocityNode = (function (_super) {
+ __extends(ParticleVelocityNode, _super);
+ /**
+ * Creates a new ParticleVelocityNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] velocity Defines the default velocity vector of the node, used when in global mode.
+ */
+ function ParticleVelocityNode(mode /*uint*/, velocity) {
+ if (velocity === void 0) { velocity = null; }
+ _super.call(this, "ParticleVelocity", mode, 3);
+ this._pStateClass = ParticleVelocityState;
+ this._iVelocity = velocity || new Vector3D();
+ }
+ /**
+ * @inheritDoc
+ */
+ ParticleVelocityNode.prototype.getAGALVertexCode = function (shaderObject, animationRegisterCache) {
+ var velocityValue = (this._pMode == ParticlePropertiesMode.GLOBAL) ? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleVelocityState.VELOCITY_INDEX, velocityValue.index);
+ var distance = animationRegisterCache.getFreeVertexVectorTemp();
+ var code = "";
+ code += "mul " + distance + "," + animationRegisterCache.vertexTime + "," + velocityValue + "\n";
+ code += "add " + animationRegisterCache.positionTarget + ".xyz," + distance + "," + animationRegisterCache.positionTarget + ".xyz\n";
+ if (animationRegisterCache.needVelocity)
+ code += "add " + animationRegisterCache.velocityTarget + ".xyz," + velocityValue + ".xyz," + animationRegisterCache.velocityTarget + ".xyz\n";
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleVelocityNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleVelocityNode.prototype._iGeneratePropertyOfOneParticle = function (param) {
+ var _tempVelocity = param[ParticleVelocityNode.VELOCITY_VECTOR3D];
+ if (!_tempVelocity)
+ throw new Error("there is no " + ParticleVelocityNode.VELOCITY_VECTOR3D + " in param!");
+ this._pOneData[0] = _tempVelocity.x;
+ this._pOneData[1] = _tempVelocity.y;
+ this._pOneData[2] = _tempVelocity.z;
+ };
+ /**
+ * Reference for velocity node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
object representing the direction of movement on the particle.
+ */
+ ParticleVelocityNode.VELOCITY_VECTOR3D = "VelocityVector3D";
+ return ParticleVelocityNode;
+})(ParticleNodeBase);
+module.exports = ParticleVelocityNode;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/nodes/particlevelocitynode.ts"],"names":["ParticleVelocityNode","ParticleVelocityNode.constructor","ParticleVelocityNode.getAGALVertexCode","ParticleVelocityNode.getAnimationState","ParticleVelocityNode._iGeneratePropertyOfOneParticle"],"mappings":"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","file":"animators/nodes/ParticleVelocityNode.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\n\nimport ParticleProperties\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleProperties\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleNodeBase\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleNodeBase\");\nimport ParticleVelocityState\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleVelocityState\");\n\n/**\n * A particle animation node used to set the starting velocity of a particle.\n */\nclass ParticleVelocityNode extends ParticleNodeBase\n{\n\t/** @private */\n\tpublic _iVelocity:Vector3D;\n\n\t/**\n\t * Reference for velocity node properties on a single particle (when in local property mode).\n\t * Expects a <code>Vector3D</code> object representing the direction of movement on the particle.\n\t */\n\tpublic static VELOCITY_VECTOR3D:string = \"VelocityVector3D\";\n\n\t/**\n\t * Creates a new <code>ParticleVelocityNode</code>\n\t *\n\t * @param               mode            Defines whether the mode of operation acts on local properties of a particle or global properties of the node.\n\t * @param    [optional] velocity        Defines the default velocity vector of the node, used when in global mode.\n\t */\n\tconstructor(mode:number /*uint*/, velocity:Vector3D = null)\n\t{\n\t\tsuper(\"ParticleVelocity\", mode, 3);\n\n\t\tthis._pStateClass = ParticleVelocityState;\n\n\t\tthis._iVelocity = velocity || new Vector3D();\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string\n\t{\n\t\tvar velocityValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();\n\t\tanimationRegisterCache.setRegisterIndex(this, ParticleVelocityState.VELOCITY_INDEX, velocityValue.index);\n\n\t\tvar distance:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();\n\t\tvar code:string = \"\";\n\t\tcode += \"mul \" + distance + \",\" + animationRegisterCache.vertexTime + \",\" + velocityValue + \"\\n\";\n\t\tcode += \"add \" + animationRegisterCache.positionTarget + \".xyz,\" + distance + \",\" + animationRegisterCache.positionTarget + \".xyz\\n\";\n\n\t\tif (animationRegisterCache.needVelocity)\n\t\t\tcode += \"add \" + animationRegisterCache.velocityTarget + \".xyz,\" + velocityValue + \".xyz,\" + animationRegisterCache.velocityTarget + \".xyz\\n\";\n\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getAnimationState(animator:AnimatorBase):ParticleVelocityState\n\t{\n\t\treturn <ParticleVelocityState> animator.getAnimationState(this);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _iGeneratePropertyOfOneParticle(param:ParticleProperties)\n\t{\n\t\tvar _tempVelocity:Vector3D = param[ParticleVelocityNode.VELOCITY_VECTOR3D];\n\t\tif (!_tempVelocity)\n\t\t\tthrow new Error(\"there is no \" + ParticleVelocityNode.VELOCITY_VECTOR3D + \" in param!\");\n\n\t\tthis._pOneData[0] = _tempVelocity.x;\n\t\tthis._pOneData[1] = _tempVelocity.y;\n\t\tthis._pOneData[2] = _tempVelocity.z;\n\t}\n}\n\nexport = ParticleVelocityNode;"]}
\ No newline at end of file
diff --git a/lib/animators/nodes/ParticleVelocityNode.ts b/lib/animators/nodes/ParticleVelocityNode.ts
new file mode 100644
index 000000000..3bdaf33fc
--- /dev/null
+++ b/lib/animators/nodes/ParticleVelocityNode.ts
@@ -0,0 +1,84 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+
+import ParticleProperties = require("awayjs-renderergl/lib/animators/data/ParticleProperties");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleVelocityState = require("awayjs-renderergl/lib/animators/states/ParticleVelocityState");
+
+/**
+ * A particle animation node used to set the starting velocity of a particle.
+ */
+class ParticleVelocityNode extends ParticleNodeBase
+{
+ /** @private */
+ public _iVelocity:Vector3D;
+
+ /**
+ * Reference for velocity node properties on a single particle (when in local property mode).
+ * Expects a Vector3D
object representing the direction of movement on the particle.
+ */
+ public static VELOCITY_VECTOR3D:string = "VelocityVector3D";
+
+ /**
+ * Creates a new ParticleVelocityNode
+ *
+ * @param mode Defines whether the mode of operation acts on local properties of a particle or global properties of the node.
+ * @param [optional] velocity Defines the default velocity vector of the node, used when in global mode.
+ */
+ constructor(mode:number /*uint*/, velocity:Vector3D = null)
+ {
+ super("ParticleVelocity", mode, 3);
+
+ this._pStateClass = ParticleVelocityState;
+
+ this._iVelocity = velocity || new Vector3D();
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAGALVertexCode(shaderObject:ShaderObjectBase, animationRegisterCache:AnimationRegisterCache):string
+ {
+ var velocityValue:ShaderRegisterElement = (this._pMode == ParticlePropertiesMode.GLOBAL)? animationRegisterCache.getFreeVertexConstant() : animationRegisterCache.getFreeVertexAttribute();
+ animationRegisterCache.setRegisterIndex(this, ParticleVelocityState.VELOCITY_INDEX, velocityValue.index);
+
+ var distance:ShaderRegisterElement = animationRegisterCache.getFreeVertexVectorTemp();
+ var code:string = "";
+ code += "mul " + distance + "," + animationRegisterCache.vertexTime + "," + velocityValue + "\n";
+ code += "add " + animationRegisterCache.positionTarget + ".xyz," + distance + "," + animationRegisterCache.positionTarget + ".xyz\n";
+
+ if (animationRegisterCache.needVelocity)
+ code += "add " + animationRegisterCache.velocityTarget + ".xyz," + velocityValue + ".xyz," + animationRegisterCache.velocityTarget + ".xyz\n";
+
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):ParticleVelocityState
+ {
+ return animator.getAnimationState(this);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _iGeneratePropertyOfOneParticle(param:ParticleProperties)
+ {
+ var _tempVelocity:Vector3D = param[ParticleVelocityNode.VELOCITY_VECTOR3D];
+ if (!_tempVelocity)
+ throw new Error("there is no " + ParticleVelocityNode.VELOCITY_VECTOR3D + " in param!");
+
+ this._pOneData[0] = _tempVelocity.x;
+ this._pOneData[1] = _tempVelocity.y;
+ this._pOneData[2] = _tempVelocity.z;
+ }
+}
+
+export = ParticleVelocityNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/SkeletonBinaryLERPNode.js b/lib/animators/nodes/SkeletonBinaryLERPNode.js
new file mode 100755
index 000000000..ab9ae20ca
--- /dev/null
+++ b/lib/animators/nodes/SkeletonBinaryLERPNode.js
@@ -0,0 +1,31 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var AnimationNodeBase = require("awayjs-core/lib/animators/nodes/AnimationNodeBase");
+var SkeletonBinaryLERPState = require("awayjs-renderergl/lib/animators/states/SkeletonBinaryLERPState");
+/**
+ * A skeleton animation node that uses two animation node inputs to blend a lineraly interpolated output of a skeleton pose.
+ */
+var SkeletonBinaryLERPNode = (function (_super) {
+ __extends(SkeletonBinaryLERPNode, _super);
+ /**
+ * Creates a new SkeletonBinaryLERPNode
object.
+ */
+ function SkeletonBinaryLERPNode() {
+ _super.call(this);
+ this._pStateClass = SkeletonBinaryLERPState;
+ }
+ /**
+ * @inheritDoc
+ */
+ SkeletonBinaryLERPNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ return SkeletonBinaryLERPNode;
+})(AnimationNodeBase);
+module.exports = SkeletonBinaryLERPNode;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9ub2Rlcy9za2VsZXRvbmJpbmFyeWxlcnBub2RlLnRzIl0sIm5hbWVzIjpbIlNrZWxldG9uQmluYXJ5TEVSUE5vZGUiLCJTa2VsZXRvbkJpbmFyeUxFUlBOb2RlLmNvbnN0cnVjdG9yIiwiU2tlbGV0b25CaW5hcnlMRVJQTm9kZS5nZXRBbmltYXRpb25TdGF0ZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsSUFBTyxpQkFBaUIsV0FBYyxtREFBbUQsQ0FBQyxDQUFDO0FBSzNGLElBQU8sdUJBQXVCLFdBQWEsZ0VBQWdFLENBQUMsQ0FBQztBQUU3RyxBQUdBOztHQURHO0lBQ0csc0JBQXNCO0lBQVNBLFVBQS9CQSxzQkFBc0JBLFVBQTBCQTtJQVlyREE7O09BRUdBO0lBQ0hBLFNBZktBLHNCQUFzQkE7UUFpQjFCQyxpQkFBT0EsQ0FBQ0E7UUFFUkEsSUFBSUEsQ0FBQ0EsWUFBWUEsR0FBR0EsdUJBQXVCQSxDQUFDQTtJQUM3Q0EsQ0FBQ0E7SUFFREQ7O09BRUdBO0lBQ0lBLGtEQUFpQkEsR0FBeEJBLFVBQXlCQSxRQUFxQkE7UUFFN0NFLE1BQU1BLENBQTJCQSxRQUFRQSxDQUFDQSxpQkFBaUJBLENBQUNBLElBQUlBLENBQUNBLENBQUNBO0lBQ25FQSxDQUFDQTtJQUNGRiw2QkFBQ0E7QUFBREEsQ0E3QkEsQUE2QkNBLEVBN0JvQyxpQkFBaUIsRUE2QnJEO0FBRUQsQUFBZ0MsaUJBQXZCLHNCQUFzQixDQUFDIiwiZmlsZSI6ImFuaW1hdG9ycy9ub2Rlcy9Ta2VsZXRvbkJpbmFyeUxFUlBOb2RlLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2JiYXRlbWFuL1dlYnN0b3JtUHJvamVjdHMvYXdheWpzLXJlbmRlcmVyZ2wvIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEFuaW1hdGlvbk5vZGVCYXNlXHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvYW5pbWF0b3JzL25vZGVzL0FuaW1hdGlvbk5vZGVCYXNlXCIpO1xuaW1wb3J0IFZlY3RvcjNEXHRcdFx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvY29yZS9nZW9tL1ZlY3RvcjNEXCIpO1xuXG5pbXBvcnQgQW5pbWF0b3JCYXNlXHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2FuaW1hdG9ycy9BbmltYXRvckJhc2VcIik7XG5cbmltcG9ydCBTa2VsZXRvbkJpbmFyeUxFUlBTdGF0ZVx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvc3RhdGVzL1NrZWxldG9uQmluYXJ5TEVSUFN0YXRlXCIpO1xuXG4vKipcbiAqIEEgc2tlbGV0b24gYW5pbWF0aW9uIG5vZGUgdGhhdCB1c2VzIHR3byBhbmltYXRpb24gbm9kZSBpbnB1dHMgdG8gYmxlbmQgYSBsaW5lcmFseSBpbnRlcnBvbGF0ZWQgb3V0cHV0IG9mIGEgc2tlbGV0b24gcG9zZS5cbiAqL1xuY2xhc3MgU2tlbGV0b25CaW5hcnlMRVJQTm9kZSBleHRlbmRzIEFuaW1hdGlvbk5vZGVCYXNlXG57XG5cdC8qKlxuXHQgKiBEZWZpbmVzIGlucHV0IG5vZGUgQSB0byB1c2UgZm9yIHRoZSBibGVuZGVkIG91dHB1dC5cblx0ICovXG5cdHB1YmxpYyBpbnB1dEE6QW5pbWF0aW9uTm9kZUJhc2U7XG5cblx0LyoqXG5cdCAqIERlZmluZXMgaW5wdXQgbm9kZSBCIHRvIHVzZSBmb3IgdGhlIGJsZW5kZWQgb3V0cHV0LlxuXHQgKi9cblx0cHVibGljIGlucHV0QjpBbmltYXRpb25Ob2RlQmFzZTtcblxuXHQvKipcblx0ICogQ3JlYXRlcyBhIG5ldyA8Y29kZT5Ta2VsZXRvbkJpbmFyeUxFUlBOb2RlPC9jb2RlPiBvYmplY3QuXG5cdCAqL1xuXHRjb25zdHJ1Y3RvcigpXG5cdHtcblx0XHRzdXBlcigpO1xuXG5cdFx0dGhpcy5fcFN0YXRlQ2xhc3MgPSBTa2VsZXRvbkJpbmFyeUxFUlBTdGF0ZTtcblx0fVxuXG5cdC8qKlxuXHQgKiBAaW5oZXJpdERvY1xuXHQgKi9cblx0cHVibGljIGdldEFuaW1hdGlvblN0YXRlKGFuaW1hdG9yOkFuaW1hdG9yQmFzZSk6U2tlbGV0b25CaW5hcnlMRVJQU3RhdGVcblx0e1xuXHRcdHJldHVybiA8U2tlbGV0b25CaW5hcnlMRVJQU3RhdGU+IGFuaW1hdG9yLmdldEFuaW1hdGlvblN0YXRlKHRoaXMpO1xuXHR9XG59XG5cbmV4cG9ydCA9IFNrZWxldG9uQmluYXJ5TEVSUE5vZGU7Il19
\ No newline at end of file
diff --git a/lib/animators/nodes/SkeletonBinaryLERPNode.ts b/lib/animators/nodes/SkeletonBinaryLERPNode.ts
new file mode 100644
index 000000000..c32d30f4a
--- /dev/null
+++ b/lib/animators/nodes/SkeletonBinaryLERPNode.ts
@@ -0,0 +1,42 @@
+import AnimationNodeBase = require("awayjs-core/lib/animators/nodes/AnimationNodeBase");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+
+import SkeletonBinaryLERPState = require("awayjs-renderergl/lib/animators/states/SkeletonBinaryLERPState");
+
+/**
+ * A skeleton animation node that uses two animation node inputs to blend a lineraly interpolated output of a skeleton pose.
+ */
+class SkeletonBinaryLERPNode extends AnimationNodeBase
+{
+ /**
+ * Defines input node A to use for the blended output.
+ */
+ public inputA:AnimationNodeBase;
+
+ /**
+ * Defines input node B to use for the blended output.
+ */
+ public inputB:AnimationNodeBase;
+
+ /**
+ * Creates a new SkeletonBinaryLERPNode
object.
+ */
+ constructor()
+ {
+ super();
+
+ this._pStateClass = SkeletonBinaryLERPState;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):SkeletonBinaryLERPState
+ {
+ return animator.getAnimationState(this);
+ }
+}
+
+export = SkeletonBinaryLERPNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/SkeletonClipNode.js b/lib/animators/nodes/SkeletonClipNode.js
new file mode 100755
index 000000000..abe097500
--- /dev/null
+++ b/lib/animators/nodes/SkeletonClipNode.js
@@ -0,0 +1,85 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var AnimationClipNodeBase = require("awayjs-renderergl/lib/animators/nodes/AnimationClipNodeBase");
+var SkeletonClipState = require("awayjs-renderergl/lib/animators/states/SkeletonClipState");
+/**
+ * A skeleton animation node containing time-based animation data as individual skeleton poses.
+ */
+var SkeletonClipNode = (function (_super) {
+ __extends(SkeletonClipNode, _super);
+ /**
+ * Creates a new SkeletonClipNode
object.
+ */
+ function SkeletonClipNode() {
+ _super.call(this);
+ this._frames = new Array();
+ /**
+ * Determines whether to use SLERP equations (true) or LERP equations (false) in the calculation
+ * of the output skeleton pose. Defaults to false.
+ */
+ this.highQuality = false;
+ this._pStateClass = SkeletonClipState;
+ }
+ Object.defineProperty(SkeletonClipNode.prototype, "frames", {
+ /**
+ * Returns a vector of skeleton poses representing the pose of each animation frame in the clip.
+ */
+ get: function () {
+ return this._frames;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * Adds a skeleton pose frame to the internal timeline of the animation node.
+ *
+ * @param skeletonPose The skeleton pose object to add to the timeline of the node.
+ * @param duration The specified duration of the frame in milliseconds.
+ */
+ SkeletonClipNode.prototype.addFrame = function (skeletonPose, duration /*number /*uint*/) {
+ this._frames.push(skeletonPose);
+ this._pDurations.push(duration);
+ this._pNumFrames = this._pDurations.length;
+ this._pStitchDirty = true;
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonClipNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonClipNode.prototype._pUpdateStitch = function () {
+ _super.prototype._pUpdateStitch.call(this);
+ var i = this._pNumFrames - 1;
+ var p1, p2, delta;
+ while (i--) {
+ this._pTotalDuration += this._pDurations[i];
+ p1 = this._frames[i].jointPoses[0].translation;
+ p2 = this._frames[i + 1].jointPoses[0].translation;
+ delta = p2.subtract(p1);
+ this._pTotalDelta.x += delta.x;
+ this._pTotalDelta.y += delta.y;
+ this._pTotalDelta.z += delta.z;
+ }
+ if (this._pStitchFinalFrame || !this._pLooping) {
+ this._pTotalDuration += this._pDurations[this._pNumFrames - 1];
+ p1 = this._frames[0].jointPoses[0].translation;
+ p2 = this._frames[1].jointPoses[0].translation;
+ delta = p2.subtract(p1);
+ this._pTotalDelta.x += delta.x;
+ this._pTotalDelta.y += delta.y;
+ this._pTotalDelta.z += delta.z;
+ }
+ };
+ return SkeletonClipNode;
+})(AnimationClipNodeBase);
+module.exports = SkeletonClipNode;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9ub2Rlcy9za2VsZXRvbmNsaXBub2RlLnRzIl0sIm5hbWVzIjpbIlNrZWxldG9uQ2xpcE5vZGUiLCJTa2VsZXRvbkNsaXBOb2RlLmNvbnN0cnVjdG9yIiwiU2tlbGV0b25DbGlwTm9kZS5mcmFtZXMiLCJTa2VsZXRvbkNsaXBOb2RlLmFkZEZyYW1lIiwiU2tlbGV0b25DbGlwTm9kZS5nZXRBbmltYXRpb25TdGF0ZSIsIlNrZWxldG9uQ2xpcE5vZGUuX3BVcGRhdGVTdGl0Y2giXSwibWFwcGluZ3MiOiI7Ozs7OztBQUtBLElBQU8scUJBQXFCLFdBQWEsNkRBQTZELENBQUMsQ0FBQztBQUN4RyxJQUFPLGlCQUFpQixXQUFjLDBEQUEwRCxDQUFDLENBQUM7QUFFbEcsQUFHQTs7R0FERztJQUNHLGdCQUFnQjtJQUFTQSxVQUF6QkEsZ0JBQWdCQSxVQUE4QkE7SUFrQm5EQTs7T0FFR0E7SUFDSEEsU0FyQktBLGdCQUFnQkE7UUF1QnBCQyxpQkFBT0EsQ0FBQ0E7UUFyQkRBLFlBQU9BLEdBQXVCQSxJQUFJQSxLQUFLQSxFQUFnQkEsQ0FBQ0E7UUFFaEVBOzs7V0FHR0E7UUFDSUEsZ0JBQVdBLEdBQVdBLEtBQUtBLENBQUNBO1FBaUJsQ0EsSUFBSUEsQ0FBQ0EsWUFBWUEsR0FBR0EsaUJBQWlCQSxDQUFDQTtJQUN2Q0EsQ0FBQ0E7SUFiREQsc0JBQVdBLG9DQUFNQTtRQUhqQkE7O1dBRUdBO2FBQ0hBO1lBRUNFLE1BQU1BLENBQUNBLElBQUlBLENBQUNBLE9BQU9BLENBQUNBO1FBQ3JCQSxDQUFDQTs7O09BQUFGO0lBWURBOzs7OztPQUtHQTtJQUNJQSxtQ0FBUUEsR0FBZkEsVUFBZ0JBLFlBQXlCQSxFQUFFQSxRQUFRQSxDQUFRQSxpQkFBREEsQUFBa0JBO1FBRTNFRyxJQUFJQSxDQUFDQSxPQUFPQSxDQUFDQSxJQUFJQSxDQUFDQSxZQUFZQSxDQUFDQSxDQUFDQTtRQUNoQ0EsSUFBSUEsQ0FBQ0EsV0FBV0EsQ0FBQ0EsSUFBSUEsQ0FBQ0EsUUFB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QkFBZ0IsQ0FBQyIsImZpbGUiOiJhbmltYXRvcnMvbm9kZXMvU2tlbGV0b25DbGlwTm9kZS5qcyIsInNvdXJjZVJvb3QiOiIvVXNlcnMvcm9iYmF0ZW1hbi9XZWJzdG9ybVByb2plY3RzL2F3YXlqcy1yZW5kZXJlcmdsLyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBWZWN0b3IzRFx0XHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLWNvcmUvbGliL2NvcmUvZ2VvbS9WZWN0b3IzRFwiKTtcblxuaW1wb3J0IEFuaW1hdG9yQmFzZVx0XHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1zdGFnZWdsL2xpYi9hbmltYXRvcnMvQW5pbWF0b3JCYXNlXCIpO1xuXG5pbXBvcnQgU2tlbGV0b25Qb3NlXHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXJlbmRlcmVyZ2wvbGliL2FuaW1hdG9ycy9kYXRhL1NrZWxldG9uUG9zZVwiKTtcbmltcG9ydCBBbmltYXRpb25DbGlwTm9kZUJhc2VcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL25vZGVzL0FuaW1hdGlvbkNsaXBOb2RlQmFzZVwiKTtcbmltcG9ydCBTa2VsZXRvbkNsaXBTdGF0ZVx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXJlbmRlcmVyZ2wvbGliL2FuaW1hdG9ycy9zdGF0ZXMvU2tlbGV0b25DbGlwU3RhdGVcIik7XG5cbi8qKlxuICogQSBza2VsZXRvbiBhbmltYXRpb24gbm9kZSBjb250YWluaW5nIHRpbWUtYmFzZWQgYW5pbWF0aW9uIGRhdGEgYXMgaW5kaXZpZHVhbCBza2VsZXRvbiBwb3Nlcy5cbiAqL1xuY2xhc3MgU2tlbGV0b25DbGlwTm9kZSBleHRlbmRzIEFuaW1hdGlvbkNsaXBOb2RlQmFzZVxue1xuXHRwcml2YXRlIF9mcmFtZXM6QXJyYXk8U2tlbGV0b25Qb3NlPiA9IG5ldyBBcnJheTxTa2VsZXRvblBvc2U+KCk7XG5cblx0LyoqXG5cdCAqIERldGVybWluZXMgd2hldGhlciB0byB1c2UgU0xFUlAgZXF1YXRpb25zICh0cnVlKSBvciBMRVJQIGVxdWF0aW9ucyAoZmFsc2UpIGluIHRoZSBjYWxjdWxhdGlvblxuXHQgKiBvZiB0aGUgb3V0cHV0IHNrZWxldG9uIHBvc2UuIERlZmF1bHRzIHRvIGZhbHNlLlxuXHQgKi9cblx0cHVibGljIGhpZ2hRdWFsaXR5OmJvb2xlYW4gPSBmYWxzZTtcblxuXHQvKipcblx0ICogUmV0dXJucyBhIHZlY3RvciBvZiBza2VsZXRvbiBwb3NlcyByZXByZXNlbnRpbmcgdGhlIHBvc2Ugb2YgZWFjaCBhbmltYXRpb24gZnJhbWUgaW4gdGhlIGNsaXAuXG5cdCAqL1xuXHRwdWJsaWMgZ2V0IGZyYW1lcygpOkFycmF5PFNrZWxldG9uUG9zZT5cblx0e1xuXHRcdHJldHVybiB0aGlzLl9mcmFtZXM7XG5cdH1cblxuXHQvKipcblx0ICogQ3JlYXRlcyBhIG5ldyA8Y29kZT5Ta2VsZXRvbkNsaXBOb2RlPC9jb2RlPiBvYmplY3QuXG5cdCAqL1xuXHRjb25zdHJ1Y3RvcigpXG5cdHtcblx0XHRzdXBlcigpO1xuXG5cdFx0dGhpcy5fcFN0YXRlQ2xhc3MgPSBTa2VsZXRvbkNsaXBTdGF0ZTtcblx0fVxuXG5cdC8qKlxuXHQgKiBBZGRzIGEgc2tlbGV0b24gcG9zZSBmcmFtZSB0byB0aGUgaW50ZXJuYWwgdGltZWxpbmUgb2YgdGhlIGFuaW1hdGlvbiBub2RlLlxuXHQgKlxuXHQgKiBAcGFyYW0gc2tlbGV0b25Qb3NlIFRoZSBza2VsZXRvbiBwb3NlIG9iamVjdCB0byBhZGQgdG8gdGhlIHRpbWVsaW5lIG9mIHRoZSBub2RlLlxuXHQgKiBAcGFyYW0gZHVyYXRpb24gVGhlIHNwZWNpZmllZCBkdXJhdGlvbiBvZiB0aGUgZnJhbWUgaW4gbWlsbGlzZWNvbmRzLlxuXHQgKi9cblx0cHVibGljIGFkZEZyYW1lKHNrZWxldG9uUG9zZTpTa2VsZXRvblBvc2UsIGR1cmF0aW9uOm51bWJlciAvKm51bWJlciAvKnVpbnQqLylcblx0e1xuXHRcdHRoaXMuX2ZyYW1lcy5wdXNoKHNrZWxldG9uUG9zZSk7XG5cdFx0dGhpcy5fcER1cmF0aW9ucy5wdXNoKGR1cmF0aW9uKTtcblxuXHRcdHRoaXMuX3BOdW1GcmFtZXMgPSB0aGlzLl9wRHVyYXRpb25zLmxlbmd0aDtcblxuXHRcdHRoaXMuX3BTdGl0Y2hEaXJ0eSA9IHRydWU7XG5cdH1cblxuXHQvKipcblx0ICogQGluaGVyaXREb2Ncblx0ICovXG5cdHB1YmxpYyBnZXRBbmltYXRpb25TdGF0ZShhbmltYXRvcjpBbmltYXRvckJhc2UpOlNrZWxldG9uQ2xpcFN0YXRlXG5cdHtcblx0XHRyZXR1cm4gPFNrZWxldG9uQ2xpcFN0YXRlPiBhbmltYXRvci5nZXRBbmltYXRpb25TdGF0ZSh0aGlzKTtcblx0fVxuXG5cdC8qKlxuXHQgKiBAaW5oZXJpdERvY1xuXHQgKi9cblx0cHVibGljIF9wVXBkYXRlU3RpdGNoKClcblx0e1xuXHRcdHN1cGVyLl9wVXBkYXRlU3RpdGNoKCk7XG5cblx0XHR2YXIgaTpudW1iZXIgLyp1aW50Ki8gPSB0aGlzLl9wTnVtRnJhbWVzIC0gMTtcblx0XHR2YXIgcDE6VmVjdG9yM0QsIHAyOlZlY3RvcjNELCBkZWx0YTpWZWN0b3IzRDtcblx0XHR3aGlsZSAoaS0tKSB7XG5cdFx0XHR0aGlzLl9wVG90YWxEdXJhdGlvbiArPSB0aGlzLl9wRHVyYXRpb25zW2ldO1xuXHRcdFx0cDEgPSB0aGlzLl9mcmFtZXNbaV0uam9pbnRQb3Nlc1swXS50cmFuc2xhdGlvbjtcblx0XHRcdHAyID0gdGhpcy5fZnJhbWVzW2kgKyAxXS5qb2ludFBvc2VzWzBdLnRyYW5zbGF0aW9uO1xuXHRcdFx0ZGVsdGEgPSBwMi5zdWJ0cmFjdChwMSk7XG5cdFx0XHR0aGlzLl9wVG90YWxEZWx0YS54ICs9IGRlbHRhLng7XG5cdFx0XHR0aGlzLl9wVG90YWxEZWx0YS55ICs9IGRlbHRhLnk7XG5cdFx0XHR0aGlzLl9wVG90YWxEZWx0YS56ICs9IGRlbHRhLno7XG5cdFx0fVxuXG5cdFx0aWYgKHRoaXMuX3BTdGl0Y2hGaW5hbEZyYW1lIHx8ICF0aGlzLl9wTG9vcGluZykge1xuXHRcdFx0dGhpcy5fcFRvdGFsRHVyYXRpb24gKz0gdGhpcy5fcER1cmF0aW9uc1t0aGlzLl9wTnVtRnJhbWVzIC0gMV07XG5cdFx0XHRwMSA9IHRoaXMuX2ZyYW1lc1swXS5qb2ludFBvc2VzWzBdLnRyYW5zbGF0aW9uO1xuXHRcdFx0cDIgPSB0aGlzLl9mcmFtZXNbMV0uam9pbnRQb3Nlc1swXS50cmFuc2xhdGlvbjtcblx0XHRcdGRlbHRhID0gcDIuc3VidHJhY3QocDEpO1xuXHRcdFx0dGhpcy5fcFRvdGFsRGVsdGEueCArPSBkZWx0YS54O1xuXHRcdFx0dGhpcy5fcFRvdGFsRGVsdGEueSArPSBkZWx0YS55O1xuXHRcdFx0dGhpcy5fcFRvdGFsRGVsdGEueiArPSBkZWx0YS56O1xuXHRcdH1cblx0fVxufVxuXG5leHBvcnQgPSBTa2VsZXRvbkNsaXBOb2RlOyJdfQ==
\ No newline at end of file
diff --git a/lib/animators/nodes/SkeletonClipNode.ts b/lib/animators/nodes/SkeletonClipNode.ts
new file mode 100644
index 000000000..daee39fdd
--- /dev/null
+++ b/lib/animators/nodes/SkeletonClipNode.ts
@@ -0,0 +1,95 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+
+import SkeletonPose = require("awayjs-renderergl/lib/animators/data/SkeletonPose");
+import AnimationClipNodeBase = require("awayjs-renderergl/lib/animators/nodes/AnimationClipNodeBase");
+import SkeletonClipState = require("awayjs-renderergl/lib/animators/states/SkeletonClipState");
+
+/**
+ * A skeleton animation node containing time-based animation data as individual skeleton poses.
+ */
+class SkeletonClipNode extends AnimationClipNodeBase
+{
+ private _frames:Array = new Array();
+
+ /**
+ * Determines whether to use SLERP equations (true) or LERP equations (false) in the calculation
+ * of the output skeleton pose. Defaults to false.
+ */
+ public highQuality:boolean = false;
+
+ /**
+ * Returns a vector of skeleton poses representing the pose of each animation frame in the clip.
+ */
+ public get frames():Array
+ {
+ return this._frames;
+ }
+
+ /**
+ * Creates a new SkeletonClipNode
object.
+ */
+ constructor()
+ {
+ super();
+
+ this._pStateClass = SkeletonClipState;
+ }
+
+ /**
+ * Adds a skeleton pose frame to the internal timeline of the animation node.
+ *
+ * @param skeletonPose The skeleton pose object to add to the timeline of the node.
+ * @param duration The specified duration of the frame in milliseconds.
+ */
+ public addFrame(skeletonPose:SkeletonPose, duration:number /*number /*uint*/)
+ {
+ this._frames.push(skeletonPose);
+ this._pDurations.push(duration);
+
+ this._pNumFrames = this._pDurations.length;
+
+ this._pStitchDirty = true;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):SkeletonClipState
+ {
+ return animator.getAnimationState(this);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pUpdateStitch()
+ {
+ super._pUpdateStitch();
+
+ var i:number /*uint*/ = this._pNumFrames - 1;
+ var p1:Vector3D, p2:Vector3D, delta:Vector3D;
+ while (i--) {
+ this._pTotalDuration += this._pDurations[i];
+ p1 = this._frames[i].jointPoses[0].translation;
+ p2 = this._frames[i + 1].jointPoses[0].translation;
+ delta = p2.subtract(p1);
+ this._pTotalDelta.x += delta.x;
+ this._pTotalDelta.y += delta.y;
+ this._pTotalDelta.z += delta.z;
+ }
+
+ if (this._pStitchFinalFrame || !this._pLooping) {
+ this._pTotalDuration += this._pDurations[this._pNumFrames - 1];
+ p1 = this._frames[0].jointPoses[0].translation;
+ p2 = this._frames[1].jointPoses[0].translation;
+ delta = p2.subtract(p1);
+ this._pTotalDelta.x += delta.x;
+ this._pTotalDelta.y += delta.y;
+ this._pTotalDelta.z += delta.z;
+ }
+ }
+}
+
+export = SkeletonClipNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/SkeletonDifferenceNode.js b/lib/animators/nodes/SkeletonDifferenceNode.js
new file mode 100755
index 000000000..46c8fd398
--- /dev/null
+++ b/lib/animators/nodes/SkeletonDifferenceNode.js
@@ -0,0 +1,31 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var AnimationNodeBase = require("awayjs-core/lib/animators/nodes/AnimationNodeBase");
+var SkeletonDifferenceState = require("awayjs-renderergl/lib/animators/states/SkeletonDifferenceState");
+/**
+ * A skeleton animation node that uses a difference input pose with a base input pose to blend a linearly interpolated output of a skeleton pose.
+ */
+var SkeletonDifferenceNode = (function (_super) {
+ __extends(SkeletonDifferenceNode, _super);
+ /**
+ * Creates a new SkeletonAdditiveNode
object.
+ */
+ function SkeletonDifferenceNode() {
+ _super.call(this);
+ this._pStateClass = SkeletonDifferenceState;
+ }
+ /**
+ * @inheritDoc
+ */
+ SkeletonDifferenceNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ return SkeletonDifferenceNode;
+})(AnimationNodeBase);
+module.exports = SkeletonDifferenceNode;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9ub2Rlcy9za2VsZXRvbmRpZmZlcmVuY2Vub2RlLnRzIl0sIm5hbWVzIjpbIlNrZWxldG9uRGlmZmVyZW5jZU5vZGUiLCJTa2VsZXRvbkRpZmZlcmVuY2VOb2RlLmNvbnN0cnVjdG9yIiwiU2tlbGV0b25EaWZmZXJlbmNlTm9kZS5nZXRBbmltYXRpb25TdGF0ZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsSUFBTyxpQkFBaUIsV0FBYyxtREFBbUQsQ0FBQyxDQUFDO0FBSTNGLElBQU8sdUJBQXVCLFdBQWEsZ0VBQWdFLENBQUMsQ0FBQztBQUU3RyxBQUdBOztHQURHO0lBQ0csc0JBQXNCO0lBQVNBLFVBQS9CQSxzQkFBc0JBLFVBQTBCQTtJQVlyREE7O09BRUdBO0lBQ0hBLFNBZktBLHNCQUFzQkE7UUFpQjFCQyxpQkFBT0EsQ0FBQ0E7UUFFUkEsSUFBSUEsQ0FBQ0EsWUFBWUEsR0FBR0EsdUJBQXVCQSxDQUFDQTtJQUM3Q0EsQ0FBQ0E7SUFFREQ7O09BRUdBO0lBQ0lBLGtEQUFpQkEsR0FBeEJBLFVBQXlCQSxRQUFxQkE7UUFFN0NFLE1BQU1BLENBQTJCQSxRQUFRQSxDQUFDQSxpQkFBaUJBLENBQUNBLElBQUlBLENBQUNBLENBQUNBO0lBQ25FQSxDQUFDQTtJQUNGRiw2QkFBQ0E7QUFBREEsQ0E3QkEsQUE2QkNBLEVBN0JvQyxpQkFBaUIsRUE2QnJEO0FBRUQsQUFBK0IsaUJBQXRCLHNCQUFzQixDQUFBIiwiZmlsZSI6ImFuaW1hdG9ycy9ub2Rlcy9Ta2VsZXRvbkRpZmZlcmVuY2VOb2RlLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2JiYXRlbWFuL1dlYnN0b3JtUHJvamVjdHMvYXdheWpzLXJlbmRlcmVyZ2wvIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEFuaW1hdGlvbk5vZGVCYXNlXHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvYW5pbWF0b3JzL25vZGVzL0FuaW1hdGlvbk5vZGVCYXNlXCIpO1xuXG5pbXBvcnQgQW5pbWF0b3JCYXNlXHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2FuaW1hdG9ycy9BbmltYXRvckJhc2VcIik7XG5cbmltcG9ydCBTa2VsZXRvbkRpZmZlcmVuY2VTdGF0ZVx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvc3RhdGVzL1NrZWxldG9uRGlmZmVyZW5jZVN0YXRlXCIpO1xuXG4vKipcbiAqIEEgc2tlbGV0b24gYW5pbWF0aW9uIG5vZGUgdGhhdCB1c2VzIGEgZGlmZmVyZW5jZSBpbnB1dCBwb3NlIHdpdGggYSBiYXNlIGlucHV0IHBvc2UgdG8gYmxlbmQgYSBsaW5lYXJseSBpbnRlcnBvbGF0ZWQgb3V0cHV0IG9mIGEgc2tlbGV0b24gcG9zZS5cbiAqL1xuY2xhc3MgU2tlbGV0b25EaWZmZXJlbmNlTm9kZSBleHRlbmRzIEFuaW1hdGlvbk5vZGVCYXNlXG57XG5cdC8qKlxuXHQgKiBEZWZpbmVzIGEgYmFzZSBpbnB1dCBub2RlIHRvIHVzZSBmb3IgdGhlIGJsZW5kZWQgb3V0cHV0LlxuXHQgKi9cblx0cHVibGljIGJhc2VJbnB1dDpBbmltYXRpb25Ob2RlQmFzZTtcblxuXHQvKipcblx0ICogRGVmaW5lcyBhIGRpZmZlcmVuY2UgaW5wdXQgbm9kZSB0byB1c2UgZm9yIHRoZSBibGVuZGVkIG91dHB1dC5cblx0ICovXG5cdHB1YmxpYyBkaWZmZXJlbmNlSW5wdXQ6QW5pbWF0aW9uTm9kZUJhc2U7XG5cblx0LyoqXG5cdCAqIENyZWF0ZXMgYSBuZXcgPGNvZGU+U2tlbGV0b25BZGRpdGl2ZU5vZGU8L2NvZGU+IG9iamVjdC5cblx0ICovXG5cdGNvbnN0cnVjdG9yKClcblx0e1xuXHRcdHN1cGVyKCk7XG5cblx0XHR0aGlzLl9wU3RhdGVDbGFzcyA9IFNrZWxldG9uRGlmZmVyZW5jZVN0YXRlO1xuXHR9XG5cblx0LyoqXG5cdCAqIEBpbmhlcml0RG9jXG5cdCAqL1xuXHRwdWJsaWMgZ2V0QW5pbWF0aW9uU3RhdGUoYW5pbWF0b3I6QW5pbWF0b3JCYXNlKTpTa2VsZXRvbkRpZmZlcmVuY2VTdGF0ZVxuXHR7XG5cdFx0cmV0dXJuIDxTa2VsZXRvbkRpZmZlcmVuY2VTdGF0ZT4gYW5pbWF0b3IuZ2V0QW5pbWF0aW9uU3RhdGUodGhpcyk7XG5cdH1cbn1cblxuZXhwb3J0ID0gU2tlbGV0b25EaWZmZXJlbmNlTm9kZSJdfQ==
\ No newline at end of file
diff --git a/lib/animators/nodes/SkeletonDifferenceNode.ts b/lib/animators/nodes/SkeletonDifferenceNode.ts
new file mode 100644
index 000000000..474430003
--- /dev/null
+++ b/lib/animators/nodes/SkeletonDifferenceNode.ts
@@ -0,0 +1,41 @@
+import AnimationNodeBase = require("awayjs-core/lib/animators/nodes/AnimationNodeBase");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+
+import SkeletonDifferenceState = require("awayjs-renderergl/lib/animators/states/SkeletonDifferenceState");
+
+/**
+ * A skeleton animation node that uses a difference input pose with a base input pose to blend a linearly interpolated output of a skeleton pose.
+ */
+class SkeletonDifferenceNode extends AnimationNodeBase
+{
+ /**
+ * Defines a base input node to use for the blended output.
+ */
+ public baseInput:AnimationNodeBase;
+
+ /**
+ * Defines a difference input node to use for the blended output.
+ */
+ public differenceInput:AnimationNodeBase;
+
+ /**
+ * Creates a new SkeletonAdditiveNode
object.
+ */
+ constructor()
+ {
+ super();
+
+ this._pStateClass = SkeletonDifferenceState;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):SkeletonDifferenceState
+ {
+ return animator.getAnimationState(this);
+ }
+}
+
+export = SkeletonDifferenceNode
\ No newline at end of file
diff --git a/lib/animators/nodes/SkeletonDirectionalNode.js b/lib/animators/nodes/SkeletonDirectionalNode.js
new file mode 100755
index 000000000..cb5105d92
--- /dev/null
+++ b/lib/animators/nodes/SkeletonDirectionalNode.js
@@ -0,0 +1,28 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var AnimationNodeBase = require("awayjs-core/lib/animators/nodes/AnimationNodeBase");
+var SkeletonDirectionalState = require("awayjs-renderergl/lib/animators/states/SkeletonDirectionalState");
+/**
+ * A skeleton animation node that uses four directional input poses with an input direction to blend a linearly interpolated output of a skeleton pose.
+ */
+var SkeletonDirectionalNode = (function (_super) {
+ __extends(SkeletonDirectionalNode, _super);
+ function SkeletonDirectionalNode() {
+ _super.call(this);
+ this._pStateClass = SkeletonDirectionalState;
+ }
+ /**
+ * @inheritDoc
+ */
+ SkeletonDirectionalNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ return SkeletonDirectionalNode;
+})(AnimationNodeBase);
+module.exports = SkeletonDirectionalNode;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9ub2Rlcy9za2VsZXRvbmRpcmVjdGlvbmFsbm9kZS50cyJdLCJuYW1lcyI6WyJTa2VsZXRvbkRpcmVjdGlvbmFsTm9kZSIsIlNrZWxldG9uRGlyZWN0aW9uYWxOb2RlLmNvbnN0cnVjdG9yIiwiU2tlbGV0b25EaXJlY3Rpb25hbE5vZGUuZ2V0QW5pbWF0aW9uU3RhdGUiXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQU8saUJBQWlCLFdBQWMsbURBQW1ELENBQUMsQ0FBQztBQUkzRixJQUFPLHdCQUF3QixXQUFhLGlFQUFpRSxDQUFDLENBQUM7QUFFL0csQUFHQTs7R0FERztJQUNHLHVCQUF1QjtJQUFTQSxVQUFoQ0EsdUJBQXVCQSxVQUEwQkE7SUFzQnREQSxTQXRCS0EsdUJBQXVCQTtRQXdCM0JDLGlCQUFPQSxDQUFDQTtRQUVSQSxJQUFJQSxDQUFDQSxZQUFZQSxHQUFHQSx3QkFBd0JBLENBQUNBO0lBQzlDQSxDQUFDQTtJQUVERDs7T0FFR0E7SUFDSUEsbURBQWlCQSxHQUF4QkEsVUFBeUJBLFFBQXFCQTtRQUU3Q0UsTUFBTUEsQ0FBNEJBLFFBQVFBLENBQUNBLGlCQUFpQkEsQ0FBQ0EsSUFBSUEsQ0FBQ0EsQ0FBQ0E7SUFDcEVBLENBQUNBO0lBRUZGLDhCQUFDQTtBQUFEQSxDQXJDQSxBQXFDQ0EsRUFyQ3FDLGlCQUFpQixFQXFDdEQ7QUFFRCxBQUFpQyxpQkFBeEIsdUJBQXVCLENBQUMiLCJmaWxlIjoiYW5pbWF0b3JzL25vZGVzL1NrZWxldG9uRGlyZWN0aW9uYWxOb2RlLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2JiYXRlbWFuL1dlYnN0b3JtUHJvamVjdHMvYXdheWpzLXJlbmRlcmVyZ2wvIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEFuaW1hdGlvbk5vZGVCYXNlXHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvYW5pbWF0b3JzL25vZGVzL0FuaW1hdGlvbk5vZGVCYXNlXCIpO1xuXG5pbXBvcnQgQW5pbWF0b3JCYXNlXHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2FuaW1hdG9ycy9BbmltYXRvckJhc2VcIik7XG5cbmltcG9ydCBTa2VsZXRvbkRpcmVjdGlvbmFsU3RhdGVcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL3N0YXRlcy9Ta2VsZXRvbkRpcmVjdGlvbmFsU3RhdGVcIik7XG5cbi8qKlxuICogQSBza2VsZXRvbiBhbmltYXRpb24gbm9kZSB0aGF0IHVzZXMgZm91ciBkaXJlY3Rpb25hbCBpbnB1dCBwb3NlcyB3aXRoIGFuIGlucHV0IGRpcmVjdGlvbiB0byBibGVuZCBhIGxpbmVhcmx5IGludGVycG9sYXRlZCBvdXRwdXQgb2YgYSBza2VsZXRvbiBwb3NlLlxuICovXG5jbGFzcyBTa2VsZXRvbkRpcmVjdGlvbmFsTm9kZSBleHRlbmRzIEFuaW1hdGlvbk5vZGVCYXNlXG57XG5cdC8qKlxuXHQgKiBEZWZpbmVzIHRoZSBmb3J3YXJkIGNvbmZpZ3VyZWQgaW5wdXQgbm9kZSB0byB1c2UgZm9yIHRoZSBibGVuZGVkIG91dHB1dC5cblx0ICovXG5cdHB1YmxpYyBmb3J3YXJkOkFuaW1hdGlvbk5vZGVCYXNlO1xuXG5cdC8qKlxuXHQgKiBEZWZpbmVzIHRoZSBiYWNrd2FyZHMgY29uZmlndXJlZCBpbnB1dCBub2RlIHRvIHVzZSBmb3IgdGhlIGJsZW5kZWQgb3V0cHV0LlxuXHQgKi9cblx0cHVibGljIGJhY2t3YXJkOkFuaW1hdGlvbk5vZGVCYXNlO1xuXG5cdC8qKlxuXHQgKiBEZWZpbmVzIHRoZSBsZWZ0IGNvbmZpZ3VyZWQgaW5wdXQgbm9kZSB0byB1c2UgZm9yIHRoZSBibGVuZGVkIG91dHB1dC5cblx0ICovXG5cdHB1YmxpYyBsZWZ0OkFuaW1hdGlvbk5vZGVCYXNlO1xuXG5cdC8qKlxuXHQgKiBEZWZpbmVzIHRoZSByaWdodCBjb25maWd1cmVkIGlucHV0IG5vZGUgdG8gdXNlIGZvciB0aGUgYmxlbmRlZCBvdXRwdXQuXG5cdCAqL1xuXHRwdWJsaWMgcmlnaHQ6QW5pbWF0aW9uTm9kZUJhc2U7XG5cblx0Y29uc3RydWN0b3IoKVxuXHR7XG5cdFx0c3VwZXIoKTtcblxuXHRcdHRoaXMuX3BTdGF0ZUNsYXNzID0gU2tlbGV0b25EaXJlY3Rpb25hbFN0YXRlO1xuXHR9XG5cblx0LyoqXG5cdCAqIEBpbmhlcml0RG9jXG5cdCAqL1xuXHRwdWJsaWMgZ2V0QW5pbWF0aW9uU3RhdGUoYW5pbWF0b3I6QW5pbWF0b3JCYXNlKTpTa2VsZXRvbkRpcmVjdGlvbmFsU3RhdGVcblx0e1xuXHRcdHJldHVybiA8U2tlbGV0b25EaXJlY3Rpb25hbFN0YXRlPiBhbmltYXRvci5nZXRBbmltYXRpb25TdGF0ZSh0aGlzKTtcblx0fVxuXG59XG5cbmV4cG9ydCA9IFNrZWxldG9uRGlyZWN0aW9uYWxOb2RlOyJdfQ==
\ No newline at end of file
diff --git a/lib/animators/nodes/SkeletonDirectionalNode.ts b/lib/animators/nodes/SkeletonDirectionalNode.ts
new file mode 100644
index 000000000..a9bc8ced9
--- /dev/null
+++ b/lib/animators/nodes/SkeletonDirectionalNode.ts
@@ -0,0 +1,49 @@
+import AnimationNodeBase = require("awayjs-core/lib/animators/nodes/AnimationNodeBase");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+
+import SkeletonDirectionalState = require("awayjs-renderergl/lib/animators/states/SkeletonDirectionalState");
+
+/**
+ * A skeleton animation node that uses four directional input poses with an input direction to blend a linearly interpolated output of a skeleton pose.
+ */
+class SkeletonDirectionalNode extends AnimationNodeBase
+{
+ /**
+ * Defines the forward configured input node to use for the blended output.
+ */
+ public forward:AnimationNodeBase;
+
+ /**
+ * Defines the backwards configured input node to use for the blended output.
+ */
+ public backward:AnimationNodeBase;
+
+ /**
+ * Defines the left configured input node to use for the blended output.
+ */
+ public left:AnimationNodeBase;
+
+ /**
+ * Defines the right configured input node to use for the blended output.
+ */
+ public right:AnimationNodeBase;
+
+ constructor()
+ {
+ super();
+
+ this._pStateClass = SkeletonDirectionalState;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):SkeletonDirectionalState
+ {
+ return animator.getAnimationState(this);
+ }
+
+}
+
+export = SkeletonDirectionalNode;
\ No newline at end of file
diff --git a/lib/animators/nodes/SkeletonNaryLERPNode.js b/lib/animators/nodes/SkeletonNaryLERPNode.js
new file mode 100755
index 000000000..ddb8604d0
--- /dev/null
+++ b/lib/animators/nodes/SkeletonNaryLERPNode.js
@@ -0,0 +1,61 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var AnimationNodeBase = require("awayjs-core/lib/animators/nodes/AnimationNodeBase");
+var SkeletonNaryLERPState = require("awayjs-renderergl/lib/animators/states/SkeletonNaryLERPState");
+/**
+ * A skeleton animation node that uses an n-dimensional array of animation node inputs to blend a lineraly interpolated output of a skeleton pose.
+ */
+var SkeletonNaryLERPNode = (function (_super) {
+ __extends(SkeletonNaryLERPNode, _super);
+ /**
+ * Creates a new SkeletonNaryLERPNode
object.
+ */
+ function SkeletonNaryLERPNode() {
+ _super.call(this);
+ this._iInputs = new Array();
+ this._pStateClass = SkeletonNaryLERPState;
+ }
+ Object.defineProperty(SkeletonNaryLERPNode.prototype, "numInputs", {
+ get: function () {
+ return this._numInputs;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * Returns an integer representing the input index of the given skeleton animation node.
+ *
+ * @param input The skeleton animation node for with the input index is requested.
+ */
+ SkeletonNaryLERPNode.prototype.getInputIndex = function (input) {
+ return this._iInputs.indexOf(input);
+ };
+ /**
+ * Returns the skeleton animation node object that resides at the given input index.
+ *
+ * @param index The input index for which the skeleton animation node is requested.
+ */
+ SkeletonNaryLERPNode.prototype.getInputAt = function (index /*uint*/) {
+ return this._iInputs[index];
+ };
+ /**
+ * Adds a new skeleton animation node input to the animation node.
+ */
+ SkeletonNaryLERPNode.prototype.addInput = function (input) {
+ this._iInputs[this._numInputs++] = input;
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonNaryLERPNode.prototype.getAnimationState = function (animator) {
+ return animator.getAnimationState(this);
+ };
+ return SkeletonNaryLERPNode;
+})(AnimationNodeBase);
+module.exports = SkeletonNaryLERPNode;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9ub2Rlcy9za2VsZXRvbm5hcnlsZXJwbm9kZS50cyJdLCJuYW1lcyI6WyJTa2VsZXRvbk5hcnlMRVJQTm9kZSIsIlNrZWxldG9uTmFyeUxFUlBOb2RlLmNvbnN0cnVjdG9yIiwiU2tlbGV0b25OYXJ5TEVSUE5vZGUubnVtSW5wdXRzIiwiU2tlbGV0b25OYXJ5TEVSUE5vZGUuZ2V0SW5wdXRJbmRleCIsIlNrZWxldG9uTmFyeUxFUlBOb2RlLmdldElucHV0QXQiLCJTa2VsZXRvbk5hcnlMRVJQTm9kZS5hZGRJbnB1dCIsIlNrZWxldG9uTmFyeUxFUlBOb2RlLmdldEFuaW1hdGlvblN0YXRlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxJQUFPLGlCQUFpQixXQUFjLG1EQUFtRCxDQUFDLENBQUM7QUFJM0YsSUFBTyxxQkFBcUIsV0FBYSw4REFBOEQsQ0FBQyxDQUFDO0FBRXpHLEFBR0E7O0dBREc7SUFDRyxvQkFBb0I7SUFBU0EsVUFBN0JBLG9CQUFvQkEsVUFBMEJBO0lBV25EQTs7T0FFR0E7SUFDSEEsU0FkS0Esb0JBQW9CQTtRQWdCeEJDLGlCQUFPQSxDQUFDQTtRQWRGQSxhQUFRQSxHQUE0QkEsSUFBSUEsS0FBS0EsRUFBcUJBLENBQUNBO1FBZ0J6RUEsSUFBSUEsQ0FBQ0EsWUFBWUEsR0FBR0EscUJBQXFCQSxDQUFDQTtJQUMzQ0EsQ0FBQ0E7SUFiREQsc0JBQVdBLDJDQUFTQTthQUFwQkE7WUFFQ0UsTUFBTUEsQ0FBQ0EsSUFBSUEsQ0FBQ0EsVUFBVUEsQ0FBQ0E7UUFDeEJBLENBQUNBOzs7T0FBQUY7SUFZREE7Ozs7T0FJR0E7SUFDSUEsNENBQWFBLEdBQXBCQSxVQUFxQkEsS0FBdUJBO1FBRTNDRyxNQUFNQSxDQUFDQSxJQUFJQSxDQUFDQSxRQUFRQSxDQUFDQSxPQUFPQSxDQUFDQSxLQUFLQSxDQUFDQSxDQUFDQTtJQUNyQ0EsQ0FBQ0E7SUFFREg7Ozs7T0FJR0E7SUFDSUEseUNBQVVBLEdBQWpCQSxVQUFrQkEsS0FBS0EsQ0FBUUEsUUFBREEsQUFBU0E7UUFFdENJLE1BQU1BLENBQUNBLElBQUlBLENBQUNBLFFBQVFBLENBQUNBLEtBQUtBLENBQUNBLENBQUNBO0lBQzdCQSxDQUFDQTtJQUVESjs7T0FFR0E7SUFDSUEsdUNBQVFBLEdBQWZBLFVBQWdCQSxLQUF1QkE7UUFFdENLLElBQUlBLENBQUNBLFFBQVFBLENBQUNBLElBQUlBLENBQUNBLFVBQVVBLEVBQUVBLENBQUNBLEdBQUdBLEtBQUtBLENBQUNBO0lBQzFDQSxDQUFDQTtJQUVETDs7T0FFR0E7SUFDSUEsZ0RBQWlCQSxHQUF4QkEsVUFBeUJBLFFBQXFCQTtRQUU3Q00sTUFBTUEsQ0FBeUJBLFFBQVFBLENBQUNBLGlCQUFpQkEsQ0FBQ0EsSUFBSUEsQ0FBQ0EsQ0FBQ0E7SUFDakVBLENBQUNBO0lBQ0ZOLDJCQUFDQTtBQUFEQSxDQXhEQSxBQXdEQ0EsRUF4RGtDLGlCQUFpQixFQXdEbkQ7QUFFRCxBQUE2QixpQkFBcEIsb0JBQW9CLENBQUEiLCJmaWxlIjoiYW5pbWF0b3JzL25vZGVzL1NrZWxldG9uTmFyeUxFUlBOb2RlLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2JiYXRlbWFuL1dlYnN0b3JtUHJvamVjdHMvYXdheWpzLXJlbmRlcmVyZ2wvIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEFuaW1hdGlvbk5vZGVCYXNlXHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvYW5pbWF0b3JzL25vZGVzL0FuaW1hdGlvbk5vZGVCYXNlXCIpO1xuXG5pbXBvcnQgQW5pbWF0b3JCYXNlXHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2FuaW1hdG9ycy9BbmltYXRvckJhc2VcIik7XG5cbmltcG9ydCBTa2VsZXRvbk5hcnlMRVJQU3RhdGVcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL3N0YXRlcy9Ta2VsZXRvbk5hcnlMRVJQU3RhdGVcIik7XG5cbi8qKlxuICogQSBza2VsZXRvbiBhbmltYXRpb24gbm9kZSB0aGF0IHVzZXMgYW4gbi1kaW1lbnNpb25hbCBhcnJheSBvZiBhbmltYXRpb24gbm9kZSBpbnB1dHMgdG8gYmxlbmQgYSBsaW5lcmFseSBpbnRlcnBvbGF0ZWQgb3V0cHV0IG9mIGEgc2tlbGV0b24gcG9zZS5cbiAqL1xuY2xhc3MgU2tlbGV0b25OYXJ5TEVSUE5vZGUgZXh0ZW5kcyBBbmltYXRpb25Ob2RlQmFzZVxue1xuXHRwdWJsaWMgX2lJbnB1dHM6QXJyYXk8QW5pbWF0aW9uTm9kZUJhc2U+ID0gbmV3IEFycmF5PEFuaW1hdGlvbk5vZGVCYXNlPigpO1xuXG5cdHByaXZhdGUgX251bUlucHV0czpudW1iZXIgLyp1aW50Ki87XG5cblx0cHVibGljIGdldCBudW1JbnB1dHMoKTpudW1iZXIgLyp1aW50Ki9cblx0e1xuXHRcdHJldHVybiB0aGlzLl9udW1JbnB1dHM7XG5cdH1cblxuXHQvKipcblx0ICogQ3JlYXRlcyBhIG5ldyA8Y29kZT5Ta2VsZXRvbk5hcnlMRVJQTm9kZTwvY29kZT4gb2JqZWN0LlxuXHQgKi9cblx0Y29uc3RydWN0b3IoKVxuXHR7XG5cdFx0c3VwZXIoKTtcblxuXHRcdHRoaXMuX3BTdGF0ZUNsYXNzID0gU2tlbGV0b25OYXJ5TEVSUFN0YXRlO1xuXHR9XG5cblx0LyoqXG5cdCAqIFJldHVybnMgYW4gaW50ZWdlciByZXByZXNlbnRpbmcgdGhlIGlucHV0IGluZGV4IG9mIHRoZSBnaXZlbiBza2VsZXRvbiBhbmltYXRpb24gbm9kZS5cblx0ICpcblx0ICogQHBhcmFtIGlucHV0IFRoZSBza2VsZXRvbiBhbmltYXRpb24gbm9kZSBmb3Igd2l0aCB0aGUgaW5wdXQgaW5kZXggaXMgcmVxdWVzdGVkLlxuXHQgKi9cblx0cHVibGljIGdldElucHV0SW5kZXgoaW5wdXQ6QW5pbWF0aW9uTm9kZUJhc2UpOm51bWJlciAvKmludCovXG5cdHtcblx0XHRyZXR1cm4gdGhpcy5faUlucHV0cy5pbmRleE9mKGlucHV0KTtcblx0fVxuXG5cdC8qKlxuXHQgKiBSZXR1cm5zIHRoZSBza2VsZXRvbiBhbmltYXRpb24gbm9kZSBvYmplY3QgdGhhdCByZXNpZGVzIGF0IHRoZSBnaXZlbiBpbnB1dCBpbmRleC5cblx0ICpcblx0ICogQHBhcmFtIGluZGV4IFRoZSBpbnB1dCBpbmRleCBmb3Igd2hpY2ggdGhlIHNrZWxldG9uIGFuaW1hdGlvbiBub2RlIGlzIHJlcXVlc3RlZC5cblx0ICovXG5cdHB1YmxpYyBnZXRJbnB1dEF0KGluZGV4Om51bWJlciAvKnVpbnQqLyk6QW5pbWF0aW9uTm9kZUJhc2Vcblx0e1xuXHRcdHJldHVybiB0aGlzLl9pSW5wdXRzW2luZGV4XTtcblx0fVxuXG5cdC8qKlxuXHQgKiBBZGRzIGEgbmV3IHNrZWxldG9uIGFuaW1hdGlvbiBub2RlIGlucHV0IHRvIHRoZSBhbmltYXRpb24gbm9kZS5cblx0ICovXG5cdHB1YmxpYyBhZGRJbnB1dChpbnB1dDpBbmltYXRpb25Ob2RlQmFzZSlcblx0e1xuXHRcdHRoaXMuX2lJbnB1dHNbdGhpcy5fbnVtSW5wdXRzKytdID0gaW5wdXQ7XG5cdH1cblxuXHQvKipcblx0ICogQGluaGVyaXREb2Ncblx0ICovXG5cdHB1YmxpYyBnZXRBbmltYXRpb25TdGF0ZShhbmltYXRvcjpBbmltYXRvckJhc2UpOlNrZWxldG9uTmFyeUxFUlBTdGF0ZVxuXHR7XG5cdFx0cmV0dXJuIDxTa2VsZXRvbk5hcnlMRVJQU3RhdGU+IGFuaW1hdG9yLmdldEFuaW1hdGlvblN0YXRlKHRoaXMpO1xuXHR9XG59XG5cbmV4cG9ydCA9IFNrZWxldG9uTmFyeUxFUlBOb2RlIl19
\ No newline at end of file
diff --git a/lib/animators/nodes/SkeletonNaryLERPNode.ts b/lib/animators/nodes/SkeletonNaryLERPNode.ts
new file mode 100644
index 000000000..4117de7fb
--- /dev/null
+++ b/lib/animators/nodes/SkeletonNaryLERPNode.ts
@@ -0,0 +1,68 @@
+import AnimationNodeBase = require("awayjs-core/lib/animators/nodes/AnimationNodeBase");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+
+import SkeletonNaryLERPState = require("awayjs-renderergl/lib/animators/states/SkeletonNaryLERPState");
+
+/**
+ * A skeleton animation node that uses an n-dimensional array of animation node inputs to blend a lineraly interpolated output of a skeleton pose.
+ */
+class SkeletonNaryLERPNode extends AnimationNodeBase
+{
+ public _iInputs:Array = new Array();
+
+ private _numInputs:number /*uint*/;
+
+ public get numInputs():number /*uint*/
+ {
+ return this._numInputs;
+ }
+
+ /**
+ * Creates a new SkeletonNaryLERPNode
object.
+ */
+ constructor()
+ {
+ super();
+
+ this._pStateClass = SkeletonNaryLERPState;
+ }
+
+ /**
+ * Returns an integer representing the input index of the given skeleton animation node.
+ *
+ * @param input The skeleton animation node for with the input index is requested.
+ */
+ public getInputIndex(input:AnimationNodeBase):number /*int*/
+ {
+ return this._iInputs.indexOf(input);
+ }
+
+ /**
+ * Returns the skeleton animation node object that resides at the given input index.
+ *
+ * @param index The input index for which the skeleton animation node is requested.
+ */
+ public getInputAt(index:number /*uint*/):AnimationNodeBase
+ {
+ return this._iInputs[index];
+ }
+
+ /**
+ * Adds a new skeleton animation node input to the animation node.
+ */
+ public addInput(input:AnimationNodeBase)
+ {
+ this._iInputs[this._numInputs++] = input;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getAnimationState(animator:AnimatorBase):SkeletonNaryLERPState
+ {
+ return animator.getAnimationState(this);
+ }
+}
+
+export = SkeletonNaryLERPNode
\ No newline at end of file
diff --git a/lib/animators/nodes/VertexClipNode.js b/lib/animators/nodes/VertexClipNode.js
new file mode 100755
index 000000000..9a67e5a5c
--- /dev/null
+++ b/lib/animators/nodes/VertexClipNode.js
@@ -0,0 +1,79 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var AnimationClipNodeBase = require("awayjs-renderergl/lib/animators/nodes/AnimationClipNodeBase");
+var VertexClipState = require("awayjs-renderergl/lib/animators/states/VertexClipState");
+/**
+ * A vertex animation node containing time-based animation data as individual geometry obejcts.
+ */
+var VertexClipNode = (function (_super) {
+ __extends(VertexClipNode, _super);
+ /**
+ * Creates a new VertexClipNode
object.
+ */
+ function VertexClipNode() {
+ _super.call(this);
+ this._frames = new Array();
+ this._translations = new Array();
+ this._pStateClass = VertexClipState;
+ }
+ Object.defineProperty(VertexClipNode.prototype, "frames", {
+ /**
+ * Returns a vector of geometry frames representing the vertex values of each animation frame in the clip.
+ */
+ get: function () {
+ return this._frames;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * Adds a geometry object to the internal timeline of the animation node.
+ *
+ * @param geometry The geometry object to add to the timeline of the node.
+ * @param duration The specified duration of the frame in milliseconds.
+ * @param translation The absolute translation of the frame, used in root delta calculations for mesh movement.
+ */
+ VertexClipNode.prototype.addFrame = function (geometry, duration /*uint*/, translation) {
+ if (translation === void 0) { translation = null; }
+ this._frames.push(geometry);
+ this._pDurations.push(duration);
+ this._translations.push(translation || new Vector3D());
+ this._pNumFrames = this._pDurations.length;
+ this._pStitchDirty = true;
+ };
+ /**
+ * @inheritDoc
+ */
+ VertexClipNode.prototype._pUpdateStitch = function () {
+ _super.prototype._pUpdateStitch.call(this);
+ var i = this._pNumFrames - 1;
+ var p1, p2, delta;
+ while (i--) {
+ this._pTotalDuration += this._pDurations[i];
+ p1 = this._translations[i];
+ p2 = this._translations[i + 1];
+ delta = p2.subtract(p1);
+ this._pTotalDelta.x += delta.x;
+ this._pTotalDelta.y += delta.y;
+ this._pTotalDelta.z += delta.z;
+ }
+ if (this._pNumFrames > 1 && (this._pStitchFinalFrame || !this._pLooping)) {
+ this._pTotalDuration += this._pDurations[this._pNumFrames - 1];
+ p1 = this._translations[0];
+ p2 = this._translations[1];
+ delta = p2.subtract(p1);
+ this._pTotalDelta.x += delta.x;
+ this._pTotalDelta.y += delta.y;
+ this._pTotalDelta.z += delta.z;
+ }
+ };
+ return VertexClipNode;
+})(AnimationClipNodeBase);
+module.exports = VertexClipNode;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9ub2Rlcy92ZXJ0ZXhjbGlwbm9kZS50cyJdLCJuYW1lcyI6WyJWZXJ0ZXhDbGlwTm9kZSIsIlZlcnRleENsaXBOb2RlLmNvbnN0cnVjdG9yIiwiVmVydGV4Q2xpcE5vZGUuZnJhbWVzIiwiVmVydGV4Q2xpcE5vZGUuYWRkRnJhbWUiLCJWZXJ0ZXhDbGlwTm9kZS5fcFVwZGF0ZVN0aXRjaCJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQ0EsSUFBTyxRQUFRLFdBQWlCLG9DQUFvQyxDQUFDLENBQUM7QUFJdEUsSUFBTyxxQkFBcUIsV0FBYSw2REFBNkQsQ0FBQyxDQUFDO0FBQ3hHLElBQU8sZUFBZSxXQUFlLHdEQUF3RCxDQUFDLENBQUM7QUFFL0YsQUFHQTs7R0FERztJQUNHLGNBQWM7SUFBU0EsVUFBdkJBLGNBQWNBLFVBQThCQTtJQWFqREE7O09BRUdBO0lBQ0hBLFNBaEJLQSxjQUFjQTtRQWtCbEJDLGlCQUFPQSxDQUFDQTtRQWhCREEsWUFBT0EsR0FBbUJBLElBQUlBLEtBQUtBLEVBQVlBLENBQUNBO1FBQ2hEQSxrQkFBYUEsR0FBbUJBLElBQUlBLEtBQUtBLEVBQVlBLENBQUNBO1FBaUI3REEsSUFBSUEsQ0FBQ0EsWUFBWUEsR0FBR0EsZUFBZUEsQ0FBQ0E7SUFDckNBLENBQUNBO0lBYkRELHNCQUFXQSxrQ0FBTUE7UUFIakJBOztXQUVHQTthQUNIQTtZQUVDRSxNQUFNQSxDQUFDQSxJQUFJQSxDQUFDQSxPQUFPQSxDQUFDQTtRQUNyQkEsQ0FBQ0E7OztPQUFBRjtJQVlEQTs7Ozs7O09BTUdBO0lBQ0lBLGlDQUFRQSxHQUFmQSxVQUFnQkEsUUFBaUJBLEVBQUVBLFFBQVFBLENBQVFBLFFBQURBLEFBQVNBLEVBQUVBLFdBQTJCQTtRQUEzQkcsMkJBQTJCQSxHQUEzQkEsa0JBQTJCQTtRQUV2RkEsSUFBSUEsQ0FBQ0EsT0FBT0EsQ0FBQ0EsSUFBSUEsQ0FBQ0EsUUFBUUEsQ0FBQ0EsQ0FBQ0E7UUFDNUJBLElBQUlBLENBQUNBLFdBQVdBLENBQUNBLElBQUlBLENBQUNBLFFBQVFBLENBQUNBLENBQUNBO1FBQ2hDQSxJQUFJQSxDQUFDQSxhQUFhQSxDQUFDQSxJQUFJQSxDQUFDQSxXQUFXQSxJQUFJQSxJQUFJQSxRQUFRQSxFQUFFQSxDQUFDQSxDQUFDQTtRQUV2REEsSUFBSUEsQ0FBQ0EsV0FBV0EsR0FBR0EsSUFBSUEsQ0FBQ0EsV0FBV0EsQ0FBQ0EsTUFBTUEsQ0FBQ0E7UUFFM0NBLElBQUlBLENBQUNBLGFBQWFBLEdBQUdBLElBQUlBLENBQUNBO0lBQzNCQSxDQUFDQTtJQUVESDs7T0FFR0E7SUFDSUEsdUNBQWNBLEdBQXJCQTtRQUVDSSxnQkFBS0EsQ0FBQ0EsY0FBY0EsV0FBRUEsQ0FBQ0E7UUFFdkJBLElBQUlBLENBQUNBLEdBQW1CQSxJQUFJQSxDQUFDQSxXQUFXQSxHQUFHQSxDQUFDQSxDQUFDQTtRQUM3Q0EsSUFBSUEsRUFBV0EsRUFBRUEsRUFBV0EsRUFBRUEsS0FBY0EsQ0FBQ0E7UUFDN0NBLE9BQU9BLENBQUNBLEVBQUVBLEVBQUVBLENBQUNBO1lBQ1pBLElBQUlBLENBQUNBLGVBQWVBLElBQUlBLElBQUlBLENBQUNBLFdBQVdBLENBQUNBLENBQUNBLENBQUNBLENBQUNBO1lBQzVDQSxFQUFFQSxHQUFHQSxJQUFJQSxDQUFDQSxhQUFhQSxDQUFDQSxDQUFDQSxDQUFDQSxDQUFDQTtZQUMzQkEsRUFBRUEsR0FBR0EsSUFBSUEsQ0FBQ0EsYUFBYUEsQ0FBQ0EsQ0FBQ0EsR0FBR0EsQ0FBQ0EsQ0FBQ0EsQ0FBQ0E7WUFDL0JBLEtBQUtBLEdBQUdBLEVBQUVBLENBQUNBLFFBQVFBLENBQUNBLEVBQUVBLENBQUNBLENBQUNBO1lBQ3hCQSxJQUFJQSxDQUFDQSxZQUFZQSxDQUFDQSxDQUFDQSxJQUFJQSxLQUFLQSxDQUFDQSxDQUFDQSxDQUFDQTtZQUMvQkEsSUFBSUEsQ0FBQ0EsWUFBWUEsQ0FBQ0EsQ0FBQ0EsSUFBSUEsS0FBS0EsQ0FBQ0EsQ0FBQ0EsQ0FBQ0E7WUFDL0JBLElBQUlBLENBQUNBLFlBQVlBLENBQUNBLENBQUNBLElBQUlBLEtBQUtBLENBQUNBLENBQUNBLENBQUNBO1FBQ2hDQSxDQUFDQTtRQUVEQSxFQUFFQSxDQUFDQSxDQUFDQSxJQUFJQSxDQUFDQSxXQUFXQSxHQUFHQSxDQUFDQSxJQUFJQSxDQUFDQSxJQUFJQSxDQUFDQSxrQkFBa0JBLElBQUlBLENBQUNBLElBQUlBLENBQUNBLFNBQVNBLENBQUNBLENBQUNBLENBQUNBLENBQUNBO1lBQzFFQSxJQUFJQSxDQUFDQSxlQUFlQSxJQUFJQSxJQUFJQSxDQUFDQSxXQUFXQSxDQUFDQSxJQUFJQSxDQUFDQSxXQUFXQSxHQUFHQSxDQUFDQSxDQUFDQSxDQUFDQTtZQUMvREEsRUFBRUEsR0FBR0EsSUFBSUEsQ0FBQ0EsYUFBYUEsQ0FBQ0EsQ0FBQ0EsQ0FBQ0EsQ0FBQ0E7WUFDM0JBLEVBQUVBLEdBQUdBLElBQUlBLENBQUNBLGFBQWFBLENBQUNBLENBQUNBLENBQUNBLENBQUNBO1lBQzNCQSxLQUFLQSxHQUFHQSxFQUFFQSxDQUFDQSxRQUFRQSxDQUFDQSxFQUFFQSxDQUFDQSxDQUFDQTtZQUN4QkEsSUFBSUEsQ0FBQ0EsWUFBWUEsQ0FBQ0EsQ0FBQ0EsSUFBSUEsS0FBS0EsQ0FBQ0EsQ0FBQ0EsQ0FBQ0E7WUFDL0JBLElBQUlBLENBQUNBLFlBQVlBLENBQUNBLENBQUNBLElBQUlBLEtBQUtBLENBQUNBLENBQUNBLENBQUNBO1lBQy9CQSxJQUFJQSxDQUFDQSxZQUFZQSxDQUFDQSxDQUFDQSxJQUFJQSxLQUFLQSxDQUFDQSxDQUFDQSxDQUFDQTtRQUNoQ0EsQ0FBQ0E7SUFDRkEsQ0FBQ0E7SUFDRkoscUJBQUNBO0FBQURBLENBdEVBLEFBc0VDQSxFQXRFNEIscUJBQXFCLEVBc0VqRDtBQUVELEFBQXdCLGlCQUFmLGNBQWMsQ0FBQyIsImZpbGUiOiJhbmltYXRvcnMvbm9kZXMvVmVydGV4Q2xpcE5vZGUuanMiLCJzb3VyY2VSb290IjoiL1VzZXJzL3JvYmJhdGVtYW4vV2Vic3Rvcm1Qcm9qZWN0cy9hd2F5anMtcmVuZGVyZXJnbC8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgR2VvbWV0cnlcdFx0XHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1jb3JlL2xpYi9jb3JlL2Jhc2UvR2VvbWV0cnlcIik7XG5pbXBvcnQgVmVjdG9yM0RcdFx0XHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1jb3JlL2xpYi9jb3JlL2dlb20vVmVjdG9yM0RcIik7XG5cbmltcG9ydCBBbmltYXRvckJhc2VcdFx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvYW5pbWF0b3JzL0FuaW1hdG9yQmFzZVwiKTtcblxuaW1wb3J0IEFuaW1hdGlvbkNsaXBOb2RlQmFzZVx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvbm9kZXMvQW5pbWF0aW9uQ2xpcE5vZGVCYXNlXCIpO1xuaW1wb3J0IFZlcnRleENsaXBTdGF0ZVx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL3N0YXRlcy9WZXJ0ZXhDbGlwU3RhdGVcIik7XG5cbi8qKlxuICogQSB2ZXJ0ZXggYW5pbWF0aW9uIG5vZGUgY29udGFpbmluZyB0aW1lLWJhc2VkIGFuaW1hdGlvbiBkYXRhIGFzIGluZGl2aWR1YWwgZ2VvbWV0cnkgb2JlamN0cy5cbiAqL1xuY2xhc3MgVmVydGV4Q2xpcE5vZGUgZXh0ZW5kcyBBbmltYXRpb25DbGlwTm9kZUJhc2Vcbntcblx0cHJpdmF0ZSBfZnJhbWVzOkFycmF5PEdlb21ldHJ5PiA9IG5ldyBBcnJheTxHZW9tZXRyeT4oKTtcblx0cHJpdmF0ZSBfdHJhbnNsYXRpb25zOkFycmF5PFZlY3RvcjNEPiA9IG5ldyBBcnJheTxWZWN0b3IzRD4oKTtcblxuXHQvKipcblx0ICogUmV0dXJucyBhIHZlY3RvciBvZiBnZW9tZXRyeSBmcmFtZXMgcmVwcmVzZW50aW5nIHRoZSB2ZXJ0ZXggdmFsdWVzIG9mIGVhY2ggYW5pbWF0aW9uIGZyYW1lIGluIHRoZSBjbGlwLlxuXHQgKi9cblx0cHVibGljIGdldCBmcmFtZXMoKTpBcnJheTxHZW9tZXRyeT5cblx0e1xuXHRcdHJldHVybiB0aGlzLl9mcmFtZXM7XG5cdH1cblxuXHQvKipcblx0ICogQ3JlYXRlcyBhIG5ldyA8Y29kZT5WZXJ0ZXhDbGlwTm9kZTwvY29kZT4gb2JqZWN0LlxuXHQgKi9cblx0Y29uc3RydWN0b3IoKVxuXHR7XG5cdFx0c3VwZXIoKTtcblxuXHRcdHRoaXMuX3BTdGF0ZUNsYXNzID0gVmVydGV4Q2xpcFN0YXRlO1xuXHR9XG5cblx0LyoqXG5cdCAqIEFkZHMgYSBnZW9tZXRyeSBvYmplY3QgdG8gdGhlIGludGVybmFsIHRpbWVsaW5lIG9mIHRoZSBhbmltYXRpb24gbm9kZS5cblx0ICpcblx0ICogQHBhcmFtIGdlb21ldHJ5IFRoZSBnZW9tZXRyeSBvYmplY3QgdG8gYWRkIHRvIHRoZSB0aW1lbGluZSBvZiB0aGUgbm9kZS5cblx0ICogQHBhcmFtIGR1cmF0aW9uIFRoZSBzcGVjaWZpZWQgZHVyYXRpb24gb2YgdGhlIGZyYW1lIGluIG1pbGxpc2Vjb25kcy5cblx0ICogQHBhcmFtIHRyYW5zbGF0aW9uIFRoZSBhYnNvbHV0ZSB0cmFuc2xhdGlvbiBvZiB0aGUgZnJhbWUsIHVzZWQgaW4gcm9vdCBkZWx0YSBjYWxjdWxhdGlvbnMgZm9yIG1lc2ggbW92ZW1lbnQuXG5cdCAqL1xuXHRwdWJsaWMgYWRkRnJhbWUoZ2VvbWV0cnk6R2VvbWV0cnksIGR1cmF0aW9uOm51bWJlciAvKnVpbnQqLywgdHJhbnNsYXRpb246VmVjdG9yM0QgPSBudWxsKVxuXHR7XG5cdFx0dGhpcy5fZnJhbWVzLnB1c2goZ2VvbWV0cnkpO1xuXHRcdHRoaXMuX3BEdXJhdGlvbnMucHVzaChkdXJhdGlvbik7XG5cdFx0dGhpcy5fdHJhbnNsYXRpb25zLnB1c2godHJhbnNsYXRpb24gfHwgbmV3IFZlY3RvcjNEKCkpO1xuXG5cdFx0dGhpcy5fcE51bUZyYW1lcyA9IHRoaXMuX3BEdXJhdGlvbnMubGVuZ3RoO1xuXG5cdFx0dGhpcy5fcFN0aXRjaERpcnR5ID0gdHJ1ZTtcblx0fVxuXG5cdC8qKlxuXHQgKiBAaW5oZXJpdERvY1xuXHQgKi9cblx0cHVibGljIF9wVXBkYXRlU3RpdGNoKClcblx0e1xuXHRcdHN1cGVyLl9wVXBkYXRlU3RpdGNoKCk7XG5cblx0XHR2YXIgaTpudW1iZXIgLyp1aW50Ki8gPSB0aGlzLl9wTnVtRnJhbWVzIC0gMTtcblx0XHR2YXIgcDE6VmVjdG9yM0QsIHAyOlZlY3RvcjNELCBkZWx0YTpWZWN0b3IzRDtcblx0XHR3aGlsZSAoaS0tKSB7XG5cdFx0XHR0aGlzLl9wVG90YWxEdXJhdGlvbiArPSB0aGlzLl9wRHVyYXRpb25zW2ldO1xuXHRcdFx0cDEgPSB0aGlzLl90cmFuc2xhdGlvbnNbaV07XG5cdFx0XHRwMiA9IHRoaXMuX3RyYW5zbGF0aW9uc1tpICsgMV07XG5cdFx0XHRkZWx0YSA9IHAyLnN1YnRyYWN0KHAxKTtcblx0XHRcdHRoaXMuX3BUb3RhbERlbHRhLnggKz0gZGVsdGEueDtcblx0XHRcdHRoaXMuX3BUb3RhbERlbHRhLnkgKz0gZGVsdGEueTtcblx0XHRcdHRoaXMuX3BUb3RhbERlbHRhLnogKz0gZGVsdGEuejtcblx0XHR9XG5cblx0XHRpZiAodGhpcy5fcE51bUZyYW1lcyA+IDEgJiYgKHRoaXMuX3BTdGl0Y2hGaW5hbEZyYW1lIHx8ICF0aGlzLl9wTG9vcGluZykpIHtcblx0XHRcdHRoaXMuX3BUb3RhbER1cmF0aW9uICs9IHRoaXMuX3BEdXJhdGlvbnNbdGhpcy5fcE51bUZyYW1lcyAtIDFdO1xuXHRcdFx0cDEgPSB0aGlzLl90cmFuc2xhdGlvbnNbMF07XG5cdFx0XHRwMiA9IHRoaXMuX3RyYW5zbGF0aW9uc1sxXTtcblx0XHRcdGRlbHRhID0gcDIuc3VidHJhY3QocDEpO1xuXHRcdFx0dGhpcy5fcFRvdGFsRGVsdGEueCArPSBkZWx0YS54O1xuXHRcdFx0dGhpcy5fcFRvdGFsRGVsdGEueSArPSBkZWx0YS55O1xuXHRcdFx0dGhpcy5fcFRvdGFsRGVsdGEueiArPSBkZWx0YS56O1xuXHRcdH1cblx0fVxufVxuXG5leHBvcnQgPSBWZXJ0ZXhDbGlwTm9kZTsiXX0=
\ No newline at end of file
diff --git a/lib/animators/nodes/VertexClipNode.ts b/lib/animators/nodes/VertexClipNode.ts
new file mode 100644
index 000000000..655a77e9d
--- /dev/null
+++ b/lib/animators/nodes/VertexClipNode.ts
@@ -0,0 +1,84 @@
+import Geometry = require("awayjs-core/lib/core/base/Geometry");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+
+import AnimationClipNodeBase = require("awayjs-renderergl/lib/animators/nodes/AnimationClipNodeBase");
+import VertexClipState = require("awayjs-renderergl/lib/animators/states/VertexClipState");
+
+/**
+ * A vertex animation node containing time-based animation data as individual geometry obejcts.
+ */
+class VertexClipNode extends AnimationClipNodeBase
+{
+ private _frames:Array = new Array();
+ private _translations:Array = new Array();
+
+ /**
+ * Returns a vector of geometry frames representing the vertex values of each animation frame in the clip.
+ */
+ public get frames():Array
+ {
+ return this._frames;
+ }
+
+ /**
+ * Creates a new VertexClipNode
object.
+ */
+ constructor()
+ {
+ super();
+
+ this._pStateClass = VertexClipState;
+ }
+
+ /**
+ * Adds a geometry object to the internal timeline of the animation node.
+ *
+ * @param geometry The geometry object to add to the timeline of the node.
+ * @param duration The specified duration of the frame in milliseconds.
+ * @param translation The absolute translation of the frame, used in root delta calculations for mesh movement.
+ */
+ public addFrame(geometry:Geometry, duration:number /*uint*/, translation:Vector3D = null)
+ {
+ this._frames.push(geometry);
+ this._pDurations.push(duration);
+ this._translations.push(translation || new Vector3D());
+
+ this._pNumFrames = this._pDurations.length;
+
+ this._pStitchDirty = true;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pUpdateStitch()
+ {
+ super._pUpdateStitch();
+
+ var i:number /*uint*/ = this._pNumFrames - 1;
+ var p1:Vector3D, p2:Vector3D, delta:Vector3D;
+ while (i--) {
+ this._pTotalDuration += this._pDurations[i];
+ p1 = this._translations[i];
+ p2 = this._translations[i + 1];
+ delta = p2.subtract(p1);
+ this._pTotalDelta.x += delta.x;
+ this._pTotalDelta.y += delta.y;
+ this._pTotalDelta.z += delta.z;
+ }
+
+ if (this._pNumFrames > 1 && (this._pStitchFinalFrame || !this._pLooping)) {
+ this._pTotalDuration += this._pDurations[this._pNumFrames - 1];
+ p1 = this._translations[0];
+ p2 = this._translations[1];
+ delta = p2.subtract(p1);
+ this._pTotalDelta.x += delta.x;
+ this._pTotalDelta.y += delta.y;
+ this._pTotalDelta.z += delta.z;
+ }
+ }
+}
+
+export = VertexClipNode;
\ No newline at end of file
diff --git a/lib/animators/states/AnimationClipState.js b/lib/animators/states/AnimationClipState.js
new file mode 100755
index 000000000..2ce335d40
--- /dev/null
+++ b/lib/animators/states/AnimationClipState.js
@@ -0,0 +1,152 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var AnimationStateBase = require("awayjs-renderergl/lib/animators/states/AnimationStateBase");
+var AnimationStateEvent = require("awayjs-renderergl/lib/events/AnimationStateEvent");
+/**
+ *
+ */
+var AnimationClipState = (function (_super) {
+ __extends(AnimationClipState, _super);
+ function AnimationClipState(animator, animationClipNode) {
+ _super.call(this, animator, animationClipNode);
+ this._pFramesDirty = true;
+ this._animationClipNode = animationClipNode;
+ }
+ Object.defineProperty(AnimationClipState.prototype, "blendWeight", {
+ /**
+ * Returns a fractional value between 0 and 1 representing the blending ratio of the current playhead position
+ * between the current frame (0) and next frame (1) of the animation.
+ *
+ * @see #currentFrame
+ * @see #nextFrame
+ */
+ get: function () {
+ if (this._pFramesDirty)
+ this._pUpdateFrames();
+ return this._pBlendWeight;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(AnimationClipState.prototype, "currentFrame", {
+ /**
+ * Returns the current frame of animation in the clip based on the internal playhead position.
+ */
+ get: function () {
+ if (this._pFramesDirty)
+ this._pUpdateFrames();
+ return this._pCurrentFrame;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(AnimationClipState.prototype, "nextFrame", {
+ /**
+ * Returns the next frame of animation in the clip based on the internal playhead position.
+ */
+ get: function () {
+ if (this._pFramesDirty)
+ this._pUpdateFrames();
+ return this._pNextFrame;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ AnimationClipState.prototype.update = function (time /*int*/) {
+ if (!this._animationClipNode.looping) {
+ if (time > this._pStartTime + this._animationClipNode.totalDuration)
+ time = this._pStartTime + this._animationClipNode.totalDuration;
+ else if (time < this._pStartTime)
+ time = this._pStartTime;
+ }
+ if (this._pTime == time - this._pStartTime)
+ return;
+ this._pUpdateTime(time);
+ };
+ /**
+ * @inheritDoc
+ */
+ AnimationClipState.prototype.phase = function (value) {
+ var time = value * this._animationClipNode.totalDuration + this._pStartTime;
+ if (this._pTime == time - this._pStartTime)
+ return;
+ this._pUpdateTime(time);
+ };
+ /**
+ * @inheritDoc
+ */
+ AnimationClipState.prototype._pUpdateTime = function (time /*int*/) {
+ this._pFramesDirty = true;
+ this._pTimeDir = (time - this._pStartTime > this._pTime) ? 1 : -1;
+ _super.prototype._pUpdateTime.call(this, time);
+ };
+ /**
+ * Updates the nodes internal playhead to determine the current and next animation frame, and the blendWeight between the two.
+ *
+ * @see #currentFrame
+ * @see #nextFrame
+ * @see #blendWeight
+ */
+ AnimationClipState.prototype._pUpdateFrames = function () {
+ this._pFramesDirty = false;
+ var looping = this._animationClipNode.looping;
+ var totalDuration = this._animationClipNode.totalDuration;
+ var lastFrame = this._animationClipNode.lastFrame;
+ var time = this._pTime;
+ //trace("time", time, totalDuration)
+ if (looping && (time >= totalDuration || time < 0)) {
+ time %= totalDuration;
+ if (time < 0)
+ time += totalDuration;
+ }
+ if (!looping && time >= totalDuration) {
+ this.notifyPlaybackComplete();
+ this._pCurrentFrame = lastFrame;
+ this._pNextFrame = lastFrame;
+ this._pBlendWeight = 0;
+ }
+ else if (!looping && time <= 0) {
+ this._pCurrentFrame = 0;
+ this._pNextFrame = 0;
+ this._pBlendWeight = 0;
+ }
+ else if (this._animationClipNode.fixedFrameRate) {
+ var t = time / totalDuration * lastFrame;
+ this._pCurrentFrame = Math.floor(t);
+ this._pBlendWeight = t - this._pCurrentFrame;
+ this._pNextFrame = this._pCurrentFrame + 1;
+ }
+ else {
+ this._pCurrentFrame = 0;
+ this._pNextFrame = 0;
+ var dur = 0, frameTime /*uint*/;
+ var durations = this._animationClipNode.durations;
+ do {
+ frameTime = dur;
+ dur += durations[this._pNextFrame];
+ this._pCurrentFrame = this._pNextFrame++;
+ } while (time > dur);
+ if (this._pCurrentFrame == lastFrame) {
+ this._pCurrentFrame = 0;
+ this._pNextFrame = 1;
+ }
+ this._pBlendWeight = (time - frameTime) / durations[this._pCurrentFrame];
+ }
+ };
+ AnimationClipState.prototype.notifyPlaybackComplete = function () {
+ if (this._animationStatePlaybackComplete == null)
+ this._animationStatePlaybackComplete = new AnimationStateEvent(AnimationStateEvent.PLAYBACK_COMPLETE, this._pAnimator, this, this._animationClipNode);
+ this._animationClipNode.dispatchEvent(this._animationStatePlaybackComplete);
+ };
+ return AnimationClipState;
+})(AnimationStateBase);
+module.exports = AnimationClipState;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/states/animationclipstate.ts"],"names":["AnimationClipState","AnimationClipState.constructor","AnimationClipState.blendWeight","AnimationClipState.currentFrame","AnimationClipState.nextFrame","AnimationClipState.update","AnimationClipState.phase","AnimationClipState._pUpdateTime","AnimationClipState._pUpdateFrames","AnimationClipState.notifyPlaybackComplete"],"mappings":"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","file":"animators/states/AnimationClipState.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\n\nimport AnimationClipNodeBase\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/AnimationClipNodeBase\");\nimport AnimationStateBase\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/AnimationStateBase\");\nimport AnimationStateEvent\t\t\t\t= require(\"awayjs-renderergl/lib/events/AnimationStateEvent\");\n\n/**\n *\n */\nclass AnimationClipState extends AnimationStateBase\n{\n\tprivate _animationClipNode:AnimationClipNodeBase;\n\tprivate _animationStatePlaybackComplete:AnimationStateEvent;\n\tpublic _pBlendWeight:number;\n\tpublic _pCurrentFrame:number /*uint*/;\n\tpublic _pNextFrame:number /*uint*/;\n\n\tpublic _pOldFrame:number /*uint*/;\n\tpublic _pTimeDir:number /*int*/;\n\tpublic _pFramesDirty:boolean = true;\n\n\t/**\n\t * Returns a fractional value between 0 and 1 representing the blending ratio of the current playhead position\n\t * between the current frame (0) and next frame (1) of the animation.\n\t *\n\t * @see #currentFrame\n\t * @see #nextFrame\n\t */\n\tpublic get blendWeight():number\n\t{\n\t\tif (this._pFramesDirty)\n\t\t\tthis._pUpdateFrames();\n\n\t\treturn this._pBlendWeight;\n\t}\n\n\t/**\n\t * Returns the current frame of animation in the clip based on the internal playhead position.\n\t */\n\tpublic get currentFrame():number /*uint*/\n\t{\n\t\tif (this._pFramesDirty)\n\t\t\tthis._pUpdateFrames();\n\n\t\treturn this._pCurrentFrame;\n\t}\n\n\t/**\n\t * Returns the next frame of animation in the clip based on the internal playhead position.\n\t */\n\tpublic get nextFrame():number /*uint*/\n\t{\n\t\tif (this._pFramesDirty)\n\t\t\tthis._pUpdateFrames();\n\n\t\treturn this._pNextFrame;\n\t}\n\n\tconstructor(animator:AnimatorBase, animationClipNode:AnimationClipNodeBase)\n\t{\n\t\tsuper(animator, animationClipNode);\n\n\t\tthis._animationClipNode = animationClipNode;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic update(time:number /*int*/)\n\t{\n\t\tif (!this._animationClipNode.looping) {\n\t\t\tif (time > this._pStartTime + this._animationClipNode.totalDuration)\n\t\t\t\ttime = this._pStartTime + this._animationClipNode.totalDuration; else if (time < this._pStartTime)\n\t\t\t\ttime = this._pStartTime;\n\t\t}\n\n\t\tif (this._pTime == time - this._pStartTime)\n\t\t\treturn;\n\n\t\tthis._pUpdateTime(time);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic phase(value:number)\n\t{\n\t\tvar time:number /*int*/ = value*this._animationClipNode.totalDuration + this._pStartTime;\n\n\t\tif (this._pTime == time - this._pStartTime)\n\t\t\treturn;\n\n\t\tthis._pUpdateTime(time);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _pUpdateTime(time:number /*int*/)\n\t{\n\t\tthis._pFramesDirty = true;\n\n\t\tthis._pTimeDir = (time - this._pStartTime > this._pTime)? 1 : -1;\n\n\t\tsuper._pUpdateTime(time);\n\t}\n\n\t/**\n\t * Updates the nodes internal playhead to determine the current and next animation frame, and the blendWeight between the two.\n\t *\n\t * @see #currentFrame\n\t * @see #nextFrame\n\t * @see #blendWeight\n\t */\n\tpublic _pUpdateFrames()\n\t{\n\t\tthis._pFramesDirty = false;\n\n\t\tvar looping:boolean = this._animationClipNode.looping;\n\t\tvar totalDuration:number /*uint*/ = this._animationClipNode.totalDuration;\n\t\tvar lastFrame:number /*uint*/ = this._animationClipNode.lastFrame;\n\t\tvar time:number /*int*/ = this._pTime;\n\n\t\t//trace(\"time\", time, totalDuration)\n\t\tif (looping && (time >= totalDuration || time < 0)) {\n\t\t\ttime %= totalDuration;\n\t\t\tif (time < 0)\n\t\t\t\ttime += totalDuration;\n\t\t}\n\n\t\tif (!looping && time >= totalDuration) {\n\t\t\tthis.notifyPlaybackComplete();\n\t\t\tthis._pCurrentFrame = lastFrame;\n\t\t\tthis._pNextFrame = lastFrame;\n\t\t\tthis._pBlendWeight = 0;\n\t\t} else if (!looping && time <= 0) {\n\t\t\tthis._pCurrentFrame = 0;\n\t\t\tthis._pNextFrame = 0;\n\t\t\tthis._pBlendWeight = 0;\n\t\t} else if (this._animationClipNode.fixedFrameRate) {\n\t\t\tvar t:number = time/totalDuration*lastFrame;\n\t\t\tthis._pCurrentFrame = Math.floor(t);\n\t\t\tthis._pBlendWeight = t - this._pCurrentFrame;\n\t\t\tthis._pNextFrame = this._pCurrentFrame + 1;\n\t\t} else {\n\t\t\tthis._pCurrentFrame = 0;\n\t\t\tthis._pNextFrame = 0;\n\n\t\t\tvar dur:number /*uint*/ = 0, frameTime:number /*uint*/;\n\t\t\tvar durations:Array<number> /*uint*/ = this._animationClipNode.durations;\n\n\t\t\tdo {\n\t\t\t\tframeTime = dur;\n\t\t\t\tdur += durations[this._pNextFrame];\n\t\t\t\tthis._pCurrentFrame = this._pNextFrame++;\n\t\t\t} while (time > dur);\n\n\t\t\tif (this._pCurrentFrame == lastFrame) {\n\t\t\t\tthis._pCurrentFrame = 0;\n\t\t\t\tthis._pNextFrame = 1;\n\t\t\t}\n\n\t\t\tthis._pBlendWeight = (time - frameTime)/durations[this._pCurrentFrame];\n\t\t}\n\t}\n\n\tprivate notifyPlaybackComplete()\n\t{\n\t\tif (this._animationStatePlaybackComplete == null)\n\t\t\tthis._animationStatePlaybackComplete = new AnimationStateEvent(AnimationStateEvent.PLAYBACK_COMPLETE, this._pAnimator, this, this._animationClipNode);\n\n\t\tthis._animationClipNode.dispatchEvent(this._animationStatePlaybackComplete);\n\t}\n}\n\nexport = AnimationClipState;"]}
\ No newline at end of file
diff --git a/lib/animators/states/AnimationClipState.ts b/lib/animators/states/AnimationClipState.ts
new file mode 100644
index 000000000..0b08e02cf
--- /dev/null
+++ b/lib/animators/states/AnimationClipState.ts
@@ -0,0 +1,176 @@
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+
+import AnimationClipNodeBase = require("awayjs-renderergl/lib/animators/nodes/AnimationClipNodeBase");
+import AnimationStateBase = require("awayjs-renderergl/lib/animators/states/AnimationStateBase");
+import AnimationStateEvent = require("awayjs-renderergl/lib/events/AnimationStateEvent");
+
+/**
+ *
+ */
+class AnimationClipState extends AnimationStateBase
+{
+ private _animationClipNode:AnimationClipNodeBase;
+ private _animationStatePlaybackComplete:AnimationStateEvent;
+ public _pBlendWeight:number;
+ public _pCurrentFrame:number /*uint*/;
+ public _pNextFrame:number /*uint*/;
+
+ public _pOldFrame:number /*uint*/;
+ public _pTimeDir:number /*int*/;
+ public _pFramesDirty:boolean = true;
+
+ /**
+ * Returns a fractional value between 0 and 1 representing the blending ratio of the current playhead position
+ * between the current frame (0) and next frame (1) of the animation.
+ *
+ * @see #currentFrame
+ * @see #nextFrame
+ */
+ public get blendWeight():number
+ {
+ if (this._pFramesDirty)
+ this._pUpdateFrames();
+
+ return this._pBlendWeight;
+ }
+
+ /**
+ * Returns the current frame of animation in the clip based on the internal playhead position.
+ */
+ public get currentFrame():number /*uint*/
+ {
+ if (this._pFramesDirty)
+ this._pUpdateFrames();
+
+ return this._pCurrentFrame;
+ }
+
+ /**
+ * Returns the next frame of animation in the clip based on the internal playhead position.
+ */
+ public get nextFrame():number /*uint*/
+ {
+ if (this._pFramesDirty)
+ this._pUpdateFrames();
+
+ return this._pNextFrame;
+ }
+
+ constructor(animator:AnimatorBase, animationClipNode:AnimationClipNodeBase)
+ {
+ super(animator, animationClipNode);
+
+ this._animationClipNode = animationClipNode;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public update(time:number /*int*/)
+ {
+ if (!this._animationClipNode.looping) {
+ if (time > this._pStartTime + this._animationClipNode.totalDuration)
+ time = this._pStartTime + this._animationClipNode.totalDuration; else if (time < this._pStartTime)
+ time = this._pStartTime;
+ }
+
+ if (this._pTime == time - this._pStartTime)
+ return;
+
+ this._pUpdateTime(time);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public phase(value:number)
+ {
+ var time:number /*int*/ = value*this._animationClipNode.totalDuration + this._pStartTime;
+
+ if (this._pTime == time - this._pStartTime)
+ return;
+
+ this._pUpdateTime(time);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pUpdateTime(time:number /*int*/)
+ {
+ this._pFramesDirty = true;
+
+ this._pTimeDir = (time - this._pStartTime > this._pTime)? 1 : -1;
+
+ super._pUpdateTime(time);
+ }
+
+ /**
+ * Updates the nodes internal playhead to determine the current and next animation frame, and the blendWeight between the two.
+ *
+ * @see #currentFrame
+ * @see #nextFrame
+ * @see #blendWeight
+ */
+ public _pUpdateFrames()
+ {
+ this._pFramesDirty = false;
+
+ var looping:boolean = this._animationClipNode.looping;
+ var totalDuration:number /*uint*/ = this._animationClipNode.totalDuration;
+ var lastFrame:number /*uint*/ = this._animationClipNode.lastFrame;
+ var time:number /*int*/ = this._pTime;
+
+ //trace("time", time, totalDuration)
+ if (looping && (time >= totalDuration || time < 0)) {
+ time %= totalDuration;
+ if (time < 0)
+ time += totalDuration;
+ }
+
+ if (!looping && time >= totalDuration) {
+ this.notifyPlaybackComplete();
+ this._pCurrentFrame = lastFrame;
+ this._pNextFrame = lastFrame;
+ this._pBlendWeight = 0;
+ } else if (!looping && time <= 0) {
+ this._pCurrentFrame = 0;
+ this._pNextFrame = 0;
+ this._pBlendWeight = 0;
+ } else if (this._animationClipNode.fixedFrameRate) {
+ var t:number = time/totalDuration*lastFrame;
+ this._pCurrentFrame = Math.floor(t);
+ this._pBlendWeight = t - this._pCurrentFrame;
+ this._pNextFrame = this._pCurrentFrame + 1;
+ } else {
+ this._pCurrentFrame = 0;
+ this._pNextFrame = 0;
+
+ var dur:number /*uint*/ = 0, frameTime:number /*uint*/;
+ var durations:Array /*uint*/ = this._animationClipNode.durations;
+
+ do {
+ frameTime = dur;
+ dur += durations[this._pNextFrame];
+ this._pCurrentFrame = this._pNextFrame++;
+ } while (time > dur);
+
+ if (this._pCurrentFrame == lastFrame) {
+ this._pCurrentFrame = 0;
+ this._pNextFrame = 1;
+ }
+
+ this._pBlendWeight = (time - frameTime)/durations[this._pCurrentFrame];
+ }
+ }
+
+ private notifyPlaybackComplete()
+ {
+ if (this._animationStatePlaybackComplete == null)
+ this._animationStatePlaybackComplete = new AnimationStateEvent(AnimationStateEvent.PLAYBACK_COMPLETE, this._pAnimator, this, this._animationClipNode);
+
+ this._animationClipNode.dispatchEvent(this._animationStatePlaybackComplete);
+ }
+}
+
+export = AnimationClipState;
\ No newline at end of file
diff --git a/lib/animators/states/AnimationStateBase.js b/lib/animators/states/AnimationStateBase.js
new file mode 100755
index 000000000..48b269e10
--- /dev/null
+++ b/lib/animators/states/AnimationStateBase.js
@@ -0,0 +1,73 @@
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+/**
+ *
+ */
+var AnimationStateBase = (function () {
+ function AnimationStateBase(animator, animationNode) {
+ this._pRootDelta = new Vector3D();
+ this._pPositionDeltaDirty = true;
+ this._pStartTime = 0;
+ this._pAnimator = animator;
+ this._pAnimationNode = animationNode;
+ }
+ Object.defineProperty(AnimationStateBase.prototype, "positionDelta", {
+ /**
+ * Returns a 3d vector representing the translation delta of the animating entity for the current timestep of animation
+ */
+ get: function () {
+ if (this._pPositionDeltaDirty) {
+ this._pUpdatePositionDelta();
+ }
+ return this._pRootDelta;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * Resets the start time of the node to a new value.
+ *
+ * @param startTime The absolute start time (in milliseconds) of the node's starting time.
+ */
+ AnimationStateBase.prototype.offset = function (startTime) {
+ this._pStartTime = startTime;
+ this._pPositionDeltaDirty = true;
+ };
+ /**
+ * Updates the configuration of the node to its current state.
+ *
+ * @param time The absolute time (in milliseconds) of the animator's play head position.
+ *
+ * @see AnimatorBase#update()
+ */
+ AnimationStateBase.prototype.update = function (time) {
+ if (this._pTime == time - this._pStartTime) {
+ return;
+ }
+ this._pUpdateTime(time);
+ };
+ /**
+ * Sets the animation phase of the node.
+ *
+ * @param value The phase value to use. 0 represents the beginning of an animation clip, 1 represents the end.
+ */
+ AnimationStateBase.prototype.phase = function (value) {
+ };
+ /**
+ * Updates the node's internal playhead position.
+ *
+ * @param time The local time (in milliseconds) of the node's playhead position.
+ */
+ AnimationStateBase.prototype._pUpdateTime = function (time) {
+ this._pTime = time - this._pStartTime;
+ this._pPositionDeltaDirty = true;
+ };
+ /**
+ * Updates the node's root delta position
+ */
+ AnimationStateBase.prototype._pUpdatePositionDelta = function () {
+ };
+ return AnimationStateBase;
+})();
+module.exports = AnimationStateBase;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9zdGF0ZXMvYW5pbWF0aW9uc3RhdGViYXNlLnRzIl0sIm5hbWVzIjpbIkFuaW1hdGlvblN0YXRlQmFzZSIsIkFuaW1hdGlvblN0YXRlQmFzZS5jb25zdHJ1Y3RvciIsIkFuaW1hdGlvblN0YXRlQmFzZS5wb3NpdGlvbkRlbHRhIiwiQW5pbWF0aW9uU3RhdGVCYXNlLm9mZnNldCIsIkFuaW1hdGlvblN0YXRlQmFzZS51cGRhdGUiLCJBbmltYXRpb25TdGF0ZUJhc2UucGhhc2UiLCJBbmltYXRpb25TdGF0ZUJhc2UuX3BVcGRhdGVUaW1lIiwiQW5pbWF0aW9uU3RhdGVCYXNlLl9wVXBkYXRlUG9zaXRpb25EZWx0YSJdLCJtYXBwaW5ncyI6IkFBQ0EsSUFBTyxRQUFRLFdBQWlCLG9DQUFvQyxDQUFDLENBQUM7QUFPdEUsQUFHQTs7R0FERztJQUNHLGtCQUFrQjtJQXdCdkJBLFNBeEJLQSxrQkFBa0JBLENBd0JYQSxRQUFxQkEsRUFBRUEsYUFBK0JBO1FBckIzREMsZ0JBQVdBLEdBQVlBLElBQUlBLFFBQVFBLEVBQUVBLENBQUNBO1FBQ3RDQSx5QkFBb0JBLEdBQVdBLElBQUlBLENBQUNBO1FBR3BDQSxnQkFBV0EsR0FBVUEsQ0FBQ0EsQ0FBQ0E7UUFtQjdCQSxJQUFJQSxDQUFDQSxVQUFVQSxHQUFHQSxRQUFRQSxDQUFDQTtRQUMzQkEsSUFBSUEsQ0FBQ0EsZUFBZUEsR0FBR0EsYUFBYUEsQ0FBQ0E7SUFDdENBLENBQUNBO0lBZkRELHNCQUFXQSw2Q0FBYUE7UUFIeEJBOztXQUVHQTthQUNIQTtZQUVDRSxFQUFFQSxDQUFDQSxDQUFDQSxJQUFJQSxDQUFDQSxvQkFBb0JBLENBQUNBLENBQUNBLENBQUNBO2dCQUUvQkEsSUFBSUEsQ0FBQ0EscUJBQXFCQSxFQUFFQSxDQUFDQTtZQUM5QkEsQ0FBQ0E7WUFFREEsTUFBTUEsQ0FBQ0EsSUFBSUEsQ0FBQ0EsV0FBV0EsQ0FBQ0E7UUFFekJBLENBQUNBOzs7T0FBQUY7SUFRREE7Ozs7T0FJR0E7SUFDSUEsbUNBQU1BLEdBQWJBLFVBQWNBLFNBQWdCQTtRQUU3QkcsSUFBSUEsQ0FBQ0EsV0FBV0EsR0FBR0EsU0FBU0EsQ0FBQ0E7UUFFN0JBLElBQUlBLENBQUNBLG9CQUFvQkEsR0FBR0EsSUFBSUEsQ0FBQ0E7SUFDbENBLENBQUNBO0lBRURIOzs7Ozs7T0FNR0E7SUFDSUEsbUNBQU1BLEdBQWJBLFVBQWNBLElBQVdBO1FBRXhCSSxFQUFFQSxDQUFDQSxDQUFDQSxJQUFJQSxDQUFDQSxNQUFNQSxJQUFJQSxJQUFJQSxHQUFHQSxJQUFJQSxDQUFDQSxXQUFXQSxDQUFDQSxDQUFDQSxDQUFDQTtZQUU1Q0EsTUFBTUEsQ0FBQ0E7UUFFUkEsQ0FBQ0E7UUFFREEsSUFBSUEsQ0FBQ0EsWUFBWUEsQ0FBQ0EsSUFBSUEsQ0FBQ0EsQ0FBQ0E7SUFFekJBLENBQUNBO0lBRURKOzs7O09BSUdBO0lBQ0lBLGtDQUFLQSxHQUFaQSxVQUFhQSxLQUFZQTtJQUd6QkssQ0FBQ0E7SUFFREw7Ozs7T0FJR0E7SUFDSUEseUNBQVlBLEdBQW5CQSxVQUFvQkEsSUFBV0E7UUFFOUJNLElBQUlBLENBQUNBLE1BQU1BLEdBQUdBLElBQUlBLEdBQUdBLElBQUlBLENBQUNBLFdBQVdBLENBQUNBO1FBRXRDQSxJQUFJQSxDQUFDQSxvQkFBb0JBLEdBQUdBLElBQUlBLENBQUNBO0lBQ2xDQSxDQUFDQTtJQUVETjs7T0FFR0E7SUFDSUEsa0RBQXFCQSxHQUE1QkE7SUFFQU8sQ0FBQ0E7SUFDRlAseUJBQUNBO0FBQURBLENBekZBLEFBeUZDQSxJQUFBO0FBRUQsQUFBNEIsaUJBQW5CLGtCQUFrQixDQUFDIiwiZmlsZSI6ImFuaW1hdG9ycy9zdGF0ZXMvQW5pbWF0aW9uU3RhdGVCYXNlLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2JiYXRlbWFuL1dlYnN0b3JtUHJvamVjdHMvYXdheWpzLXJlbmRlcmVyZ2wvIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEFuaW1hdGlvbk5vZGVCYXNlXHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvYW5pbWF0b3JzL25vZGVzL0FuaW1hdGlvbk5vZGVCYXNlXCIpO1xuaW1wb3J0IFZlY3RvcjNEXHRcdFx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvY29yZS9nZW9tL1ZlY3RvcjNEXCIpO1xuXG5pbXBvcnQgQW5pbWF0b3JCYXNlXHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2FuaW1hdG9ycy9BbmltYXRvckJhc2VcIik7XG5pbXBvcnQgSUFuaW1hdGlvblN0YXRlXHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1zdGFnZWdsL2xpYi9hbmltYXRvcnMvc3RhdGVzL0lBbmltYXRpb25TdGF0ZVwiKTtcblxuaW1wb3J0IEFuaW1hdGlvblN0YXRlRXZlbnRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9ldmVudHMvQW5pbWF0aW9uU3RhdGVFdmVudFwiKTtcblxuLyoqXG4gKlxuICovXG5jbGFzcyBBbmltYXRpb25TdGF0ZUJhc2UgaW1wbGVtZW50cyBJQW5pbWF0aW9uU3RhdGVcbntcblx0cHVibGljIF9wQW5pbWF0aW9uTm9kZTpBbmltYXRpb25Ob2RlQmFzZTtcblx0cHVibGljIF9wUm9vdERlbHRhOlZlY3RvcjNEID0gbmV3IFZlY3RvcjNEKCk7XG5cdHB1YmxpYyBfcFBvc2l0aW9uRGVsdGFEaXJ0eTpib29sZWFuID0gdHJ1ZTtcblxuXHRwdWJsaWMgX3BUaW1lOm51bWJlcjtcblx0cHVibGljIF9wU3RhcnRUaW1lOm51bWJlciA9IDA7XG5cdHB1YmxpYyBfcEFuaW1hdG9yOkFuaW1hdG9yQmFzZTtcblxuXHQvKipcblx0ICogUmV0dXJucyBhIDNkIHZlY3RvciByZXByZXNlbnRpbmcgdGhlIHRyYW5zbGF0aW9uIGRlbHRhIG9mIHRoZSBhbmltYXRpbmcgZW50aXR5IGZvciB0aGUgY3VycmVudCB0aW1lc3RlcCBvZiBhbmltYXRpb25cblx0ICovXG5cdHB1YmxpYyBnZXQgcG9zaXRpb25EZWx0YSgpOlZlY3RvcjNEXG5cdHtcblx0XHRpZiAodGhpcy5fcFBvc2l0aW9uRGVsdGFEaXJ0eSkge1xuXG5cdFx0XHR0aGlzLl9wVXBkYXRlUG9zaXRpb25EZWx0YSgpO1xuXHRcdH1cblxuXHRcdHJldHVybiB0aGlzLl9wUm9vdERlbHRhO1xuXG5cdH1cblxuXHRjb25zdHJ1Y3RvcihhbmltYXRvcjpBbmltYXRvckJhc2UsIGFuaW1hdGlvbk5vZGU6QW5pbWF0aW9uTm9kZUJhc2UpXG5cdHtcblx0XHR0aGlzLl9wQW5pbWF0b3IgPSBhbmltYXRvcjtcblx0XHR0aGlzLl9wQW5pbWF0aW9uTm9kZSA9IGFuaW1hdGlvbk5vZGU7XG5cdH1cblxuXHQvKipcblx0ICogUmVzZXRzIHRoZSBzdGFydCB0aW1lIG9mIHRoZSBub2RlIHRvIGEgIG5ldyB2YWx1ZS5cblx0ICpcblx0ICogQHBhcmFtIHN0YXJ0VGltZSBUaGUgYWJzb2x1dGUgc3RhcnQgdGltZSAoaW4gbWlsbGlzZWNvbmRzKSBvZiB0aGUgbm9kZSdzIHN0YXJ0aW5nIHRpbWUuXG5cdCAqL1xuXHRwdWJsaWMgb2Zmc2V0KHN0YXJ0VGltZTpudW1iZXIpXG5cdHtcblx0XHR0aGlzLl9wU3RhcnRUaW1lID0gc3RhcnRUaW1lO1xuXG5cdFx0dGhpcy5fcFBvc2l0aW9uRGVsdGFEaXJ0eSA9IHRydWU7XG5cdH1cblxuXHQvKipcblx0ICogVXBkYXRlcyB0aGUgY29uZmlndXJhdGlvbiBvZiB0aGUgbm9kZSB0byBpdHMgY3VycmVudCBzdGF0ZS5cblx0ICpcblx0ICogQHBhcmFtIHRpbWUgVGhlIGFic29sdXRlIHRpbWUgKGluIG1pbGxpc2Vjb25kcykgb2YgdGhlIGFuaW1hdG9yJ3MgcGxheSBoZWFkIHBvc2l0aW9uLlxuXHQgKlxuXHQgKiBAc2VlIEFuaW1hdG9yQmFzZSN1cGRhdGUoKVxuXHQgKi9cblx0cHVibGljIHVwZGF0ZSh0aW1lOm51bWJlcilcblx0e1xuXHRcdGlmICh0aGlzLl9wVGltZSA9PSB0aW1lIC0gdGhpcy5fcFN0YXJ0VGltZSkge1xuXG5cdFx0XHRyZXR1cm47XG5cblx0XHR9XG5cblx0XHR0aGlzLl9wVXBkYXRlVGltZSh0aW1lKTtcblxuXHR9XG5cblx0LyoqXG5cdCAqIFNldHMgdGhlIGFuaW1hdGlvbiBwaGFzZSBvZiB0aGUgbm9kZS5cblx0ICpcblx0ICogQHBhcmFtIHZhbHVlIFRoZSBwaGFzZSB2YWx1ZSB0byB1c2UuIDAgcmVwcmVzZW50cyB0aGUgYmVnaW5uaW5nIG9mIGFuIGFuaW1hdGlvbiBjbGlwLCAxIHJlcHJlc2VudHMgdGhlIGVuZC5cblx0ICovXG5cdHB1YmxpYyBwaGFzZSh2YWx1ZTpudW1iZXIpXG5cdHtcblxuXHR9XG5cblx0LyoqXG5cdCAqIFVwZGF0ZXMgdGhlIG5vZGUncyBpbnRlcm5hbCBwbGF5aGVhZCBwb3NpdGlvbi5cblx0ICpcblx0ICogQHBhcmFtIHRpbWUgVGhlIGxvY2FsIHRpbWUgKGluIG1pbGxpc2Vjb25kcykgb2YgdGhlIG5vZGUncyBwbGF5aGVhZCBwb3NpdGlvbi5cblx0ICovXG5cdHB1YmxpYyBfcFVwZGF0ZVRpbWUodGltZTpudW1iZXIpXG5cdHtcblx0XHR0aGlzLl9wVGltZSA9IHRpbWUgLSB0aGlzLl9wU3RhcnRUaW1lO1xuXG5cdFx0dGhpcy5fcFBvc2l0aW9uRGVsdGFEaXJ0eSA9IHRydWU7XG5cdH1cblxuXHQvKipcblx0ICogVXBkYXRlcyB0aGUgbm9kZSdzIHJvb3QgZGVsdGEgcG9zaXRpb25cblx0ICovXG5cdHB1YmxpYyBfcFVwZGF0ZVBvc2l0aW9uRGVsdGEoKVxuXHR7XG5cdH1cbn1cblxuZXhwb3J0ID0gQW5pbWF0aW9uU3RhdGVCYXNlOyJdfQ==
\ No newline at end of file
diff --git a/lib/animators/states/AnimationStateBase.ts b/lib/animators/states/AnimationStateBase.ts
new file mode 100644
index 000000000..f20f4b0f7
--- /dev/null
+++ b/lib/animators/states/AnimationStateBase.ts
@@ -0,0 +1,103 @@
+import AnimationNodeBase = require("awayjs-core/lib/animators/nodes/AnimationNodeBase");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import IAnimationState = require("awayjs-stagegl/lib/animators/states/IAnimationState");
+
+import AnimationStateEvent = require("awayjs-renderergl/lib/events/AnimationStateEvent");
+
+/**
+ *
+ */
+class AnimationStateBase implements IAnimationState
+{
+ public _pAnimationNode:AnimationNodeBase;
+ public _pRootDelta:Vector3D = new Vector3D();
+ public _pPositionDeltaDirty:boolean = true;
+
+ public _pTime:number;
+ public _pStartTime:number = 0;
+ public _pAnimator:AnimatorBase;
+
+ /**
+ * Returns a 3d vector representing the translation delta of the animating entity for the current timestep of animation
+ */
+ public get positionDelta():Vector3D
+ {
+ if (this._pPositionDeltaDirty) {
+
+ this._pUpdatePositionDelta();
+ }
+
+ return this._pRootDelta;
+
+ }
+
+ constructor(animator:AnimatorBase, animationNode:AnimationNodeBase)
+ {
+ this._pAnimator = animator;
+ this._pAnimationNode = animationNode;
+ }
+
+ /**
+ * Resets the start time of the node to a new value.
+ *
+ * @param startTime The absolute start time (in milliseconds) of the node's starting time.
+ */
+ public offset(startTime:number)
+ {
+ this._pStartTime = startTime;
+
+ this._pPositionDeltaDirty = true;
+ }
+
+ /**
+ * Updates the configuration of the node to its current state.
+ *
+ * @param time The absolute time (in milliseconds) of the animator's play head position.
+ *
+ * @see AnimatorBase#update()
+ */
+ public update(time:number)
+ {
+ if (this._pTime == time - this._pStartTime) {
+
+ return;
+
+ }
+
+ this._pUpdateTime(time);
+
+ }
+
+ /**
+ * Sets the animation phase of the node.
+ *
+ * @param value The phase value to use. 0 represents the beginning of an animation clip, 1 represents the end.
+ */
+ public phase(value:number)
+ {
+
+ }
+
+ /**
+ * Updates the node's internal playhead position.
+ *
+ * @param time The local time (in milliseconds) of the node's playhead position.
+ */
+ public _pUpdateTime(time:number)
+ {
+ this._pTime = time - this._pStartTime;
+
+ this._pPositionDeltaDirty = true;
+ }
+
+ /**
+ * Updates the node's root delta position
+ */
+ public _pUpdatePositionDelta()
+ {
+ }
+}
+
+export = AnimationStateBase;
\ No newline at end of file
diff --git a/lib/animators/states/ISkeletonAnimationState.js b/lib/animators/states/ISkeletonAnimationState.js
new file mode 100755
index 000000000..62ef01306
--- /dev/null
+++ b/lib/animators/states/ISkeletonAnimationState.js
@@ -0,0 +1,3 @@
+
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9zdGF0ZXMvaXNrZWxldG9uYW5pbWF0aW9uc3RhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYWlDIiwiZmlsZSI6ImFuaW1hdG9ycy9zdGF0ZXMvSVNrZWxldG9uQW5pbWF0aW9uU3RhdGUuanMiLCJzb3VyY2VSb290IjoiL1VzZXJzL3JvYmJhdGVtYW4vV2Vic3Rvcm1Qcm9qZWN0cy9hd2F5anMtcmVuZGVyZXJnbC8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgSUFuaW1hdGlvblN0YXRlXHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1zdGFnZWdsL2xpYi9hbmltYXRvcnMvc3RhdGVzL0lBbmltYXRpb25TdGF0ZVwiKTtcblxuaW1wb3J0IFNrZWxldG9uXHRcdFx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL2RhdGEvU2tlbGV0b25cIik7XG5pbXBvcnQgU2tlbGV0b25Qb3NlXHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXJlbmRlcmVyZ2wvbGliL2FuaW1hdG9ycy9kYXRhL1NrZWxldG9uUG9zZVwiKTtcblxuaW50ZXJmYWNlIElTa2VsZXRvbkFuaW1hdGlvblN0YXRlIGV4dGVuZHMgSUFuaW1hdGlvblN0YXRlXG57XG5cdC8qKlxuXHQgKiBSZXR1cm5zIHRoZSBvdXRwdXQgc2tlbGV0b24gcG9zZSBvZiB0aGUgYW5pbWF0aW9uIG5vZGUuXG5cdCAqL1xuXHRnZXRTa2VsZXRvblBvc2Uoc2tlbGV0b246U2tlbGV0b24pOlNrZWxldG9uUG9zZTtcbn1cblxuZXhwb3J0ID0gSVNrZWxldG9uQW5pbWF0aW9uU3RhdGU7Il19
\ No newline at end of file
diff --git a/lib/animators/states/ISkeletonAnimationState.ts b/lib/animators/states/ISkeletonAnimationState.ts
new file mode 100644
index 000000000..82040f79e
--- /dev/null
+++ b/lib/animators/states/ISkeletonAnimationState.ts
@@ -0,0 +1,14 @@
+import IAnimationState = require("awayjs-stagegl/lib/animators/states/IAnimationState");
+
+import Skeleton = require("awayjs-renderergl/lib/animators/data/Skeleton");
+import SkeletonPose = require("awayjs-renderergl/lib/animators/data/SkeletonPose");
+
+interface ISkeletonAnimationState extends IAnimationState
+{
+ /**
+ * Returns the output skeleton pose of the animation node.
+ */
+ getSkeletonPose(skeleton:Skeleton):SkeletonPose;
+}
+
+export = ISkeletonAnimationState;
\ No newline at end of file
diff --git a/lib/animators/states/IVertexAnimationState.js b/lib/animators/states/IVertexAnimationState.js
new file mode 100755
index 000000000..49d48fa42
--- /dev/null
+++ b/lib/animators/states/IVertexAnimationState.js
@@ -0,0 +1,3 @@
+
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9zdGF0ZXMvaXZlcnRleGFuaW1hdGlvbnN0YXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRCK0IiLCJmaWxlIjoiYW5pbWF0b3JzL3N0YXRlcy9JVmVydGV4QW5pbWF0aW9uU3RhdGUuanMiLCJzb3VyY2VSb290IjoiL1VzZXJzL3JvYmJhdGVtYW4vV2Vic3Rvcm1Qcm9qZWN0cy9hd2F5anMtcmVuZGVyZXJnbC8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgR2VvbWV0cnlcdFx0XHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1jb3JlL2xpYi9jb3JlL2Jhc2UvR2VvbWV0cnlcIik7XG5cbmltcG9ydCBJQW5pbWF0aW9uU3RhdGVcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2FuaW1hdG9ycy9zdGF0ZXMvSUFuaW1hdGlvblN0YXRlXCIpO1xuXG4vKipcbiAqIFByb3ZpZGVzIGFuIGludGVyZmFjZSBmb3IgYW5pbWF0aW9uIG5vZGUgY2xhc3NlcyB0aGF0IGhvbGQgYW5pbWF0aW9uIGRhdGEgZm9yIHVzZSBpbiB0aGUgVmVydGV4IGFuaW1hdG9yIGNsYXNzLlxuICpcbiAqIEBzZWUgYXdheS5hbmltYXRvcnMuVmVydGV4QW5pbWF0b3JcbiAqL1xuaW50ZXJmYWNlIElWZXJ0ZXhBbmltYXRpb25TdGF0ZSBleHRlbmRzIElBbmltYXRpb25TdGF0ZVxue1xuXHQvKipcblx0ICogUmV0dXJucyB0aGUgY3VycmVudCBnZW9tZXRyeSBmcmFtZSBvZiBhbmltYXRpb24gaW4gdGhlIGNsaXAgYmFzZWQgb24gdGhlIGludGVybmFsIHBsYXloZWFkIHBvc2l0aW9uLlxuXHQgKi9cblx0Y3VycmVudEdlb21ldHJ5Okdlb21ldHJ5OyAvL0dFVFxuXG5cdC8qKlxuXHQgKiBSZXR1cm5zIHRoZSBjdXJyZW50IGdlb21ldHJ5IGZyYW1lIG9mIGFuaW1hdGlvbiBpbiB0aGUgY2xpcCBiYXNlZCBvbiB0aGUgaW50ZXJuYWwgcGxheWhlYWQgcG9zaXRpb24uXG5cdCAqL1xuXHRuZXh0R2VvbWV0cnk6R2VvbWV0cnk7IC8vR0VUXG5cblx0LyoqXG5cdCAqIFJldHVybnMgYSBmcmFjdGlvbmFsIHZhbHVlIGJldHdlZW4gMCBhbmQgMSByZXByZXNlbnRpbmcgdGhlIGJsZW5kaW5nIHJhdGlvIG9mIHRoZSBjdXJyZW50IHBsYXloZWFkIHBvc2l0aW9uXG5cdCAqIGJldHdlZW4gdGhlIGN1cnJlbnQgZ2VvbWV0cnkgZnJhbWUgKDApIGFuZCBuZXh0IGdlb21ldHJ5IGZyYW1lICgxKSBvZiB0aGUgYW5pbWF0aW9uLlxuXHQgKi9cblx0YmxlbmRXZWlnaHQ6bnVtYmVyOyAvL0dFVFxufVxuXG5leHBvcnQgPSBJVmVydGV4QW5pbWF0aW9uU3RhdGU7Il19
\ No newline at end of file
diff --git a/lib/animators/states/IVertexAnimationState.ts b/lib/animators/states/IVertexAnimationState.ts
new file mode 100644
index 000000000..d4fa66351
--- /dev/null
+++ b/lib/animators/states/IVertexAnimationState.ts
@@ -0,0 +1,29 @@
+import Geometry = require("awayjs-core/lib/core/base/Geometry");
+
+import IAnimationState = require("awayjs-stagegl/lib/animators/states/IAnimationState");
+
+/**
+ * Provides an interface for animation node classes that hold animation data for use in the Vertex animator class.
+ *
+ * @see away.animators.VertexAnimator
+ */
+interface IVertexAnimationState extends IAnimationState
+{
+ /**
+ * Returns the current geometry frame of animation in the clip based on the internal playhead position.
+ */
+ currentGeometry:Geometry; //GET
+
+ /**
+ * Returns the current geometry frame of animation in the clip based on the internal playhead position.
+ */
+ nextGeometry:Geometry; //GET
+
+ /**
+ * Returns a fractional value between 0 and 1 representing the blending ratio of the current playhead position
+ * between the current geometry frame (0) and next geometry frame (1) of the animation.
+ */
+ blendWeight:number; //GET
+}
+
+export = IVertexAnimationState;
\ No newline at end of file
diff --git a/lib/animators/states/ParticleAccelerationState.js b/lib/animators/states/ParticleAccelerationState.js
new file mode 100755
index 000000000..af38bdd47
--- /dev/null
+++ b/lib/animators/states/ParticleAccelerationState.js
@@ -0,0 +1,58 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+/**
+ * ...
+ */
+var ParticleAccelerationState = (function (_super) {
+ __extends(ParticleAccelerationState, _super);
+ function ParticleAccelerationState(animator, particleAccelerationNode) {
+ _super.call(this, animator, particleAccelerationNode);
+ this._particleAccelerationNode = particleAccelerationNode;
+ this._acceleration = this._particleAccelerationNode._acceleration;
+ this.updateAccelerationData();
+ }
+ Object.defineProperty(ParticleAccelerationState.prototype, "acceleration", {
+ /**
+ * Defines the acceleration vector of the state, used when in global mode.
+ */
+ get: function () {
+ return this._acceleration;
+ },
+ set: function (value) {
+ this._acceleration.x = value.x;
+ this._acceleration.y = value.y;
+ this._acceleration.z = value.z;
+ this.updateAccelerationData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ ParticleAccelerationState.prototype.setRenderState = function (stage, renderable, animationSubGeometry, animationRegisterCache, camera) {
+ var index = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleAccelerationState.ACCELERATION_INDEX);
+ if (this._particleAccelerationNode.mode == ParticlePropertiesMode.LOCAL_STATIC)
+ animationSubGeometry.activateVertexBuffer(index, this._particleAccelerationNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ else
+ animationRegisterCache.setVertexConst(index, this._halfAcceleration.x, this._halfAcceleration.y, this._halfAcceleration.z);
+ };
+ ParticleAccelerationState.prototype.updateAccelerationData = function () {
+ if (this._particleAccelerationNode.mode == ParticlePropertiesMode.GLOBAL)
+ this._halfAcceleration = new Vector3D(this._acceleration.x / 2, this._acceleration.y / 2, this._acceleration.z / 2);
+ };
+ /** @private */
+ ParticleAccelerationState.ACCELERATION_INDEX = 0;
+ return ParticleAccelerationState;
+})(ParticleStateBase);
+module.exports = ParticleAccelerationState;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9zdGF0ZXMvcGFydGljbGVhY2NlbGVyYXRpb25zdGF0ZS50cyJdLCJuYW1lcyI6WyJQYXJ0aWNsZUFjY2VsZXJhdGlvblN0YXRlIiwiUGFydGljbGVBY2NlbGVyYXRpb25TdGF0ZS5jb25zdHJ1Y3RvciIsIlBhcnRpY2xlQWNjZWxlcmF0aW9uU3RhdGUuYWNjZWxlcmF0aW9uIiwiUGFydGljbGVBY2NlbGVyYXRpb25TdGF0ZS5zZXRSZW5kZXJTdGF0ZSIsIlBhcnRpY2xlQWNjZWxlcmF0aW9uU3RhdGUudXBkYXRlQWNjZWxlcmF0aW9uRGF0YSJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsSUFBTyxRQUFRLFdBQWlCLG9DQUFvQyxDQUFDLENBQUM7QUFNdEUsSUFBTywyQkFBMkIsV0FBWSw2REFBNkQsQ0FBQyxDQUFDO0FBSTdHLElBQU8sc0JBQXNCLFdBQWEsNkRBQTZELENBQUMsQ0FBQztBQUV6RyxJQUFPLGlCQUFpQixXQUFjLDBEQUEwRCxDQUFDLENBQUM7QUFFbEcsQUFHQTs7R0FERztJQUNHLHlCQUF5QjtJQUFTQSxVQUFsQ0EseUJBQXlCQSxVQUEwQkE7SUEwQnhEQSxTQTFCS0EseUJBQXlCQSxDQTBCbEJBLFFBQXlCQSxFQUFFQSx3QkFBaURBO1FBRXZGQyxrQkFBTUEsUUFBUUEsRUFBRUEsd0JBQXdCQSxDQUFDQSxDQUFDQTtRQUUxQ0EsSUFBSUEsQ0FBQ0EseUJBQXlCQSxHQUFHQSx3QkFBd0JBLENBQUNBO1FBQzFEQSxJQUFJQSxDQUFDQSxhQUFhQSxHQUFHQSxJQUFJQSxDQUFDQSx5QkFBeUJBLENBQUNBLGFBQWFBLENBQUNBO1FBRWxFQSxJQUFJQSxDQUFDQSxzQkFBc0JBLEVBQUVBLENBQUNBO0lBQy9CQSxDQUFDQTtJQXRCREQsc0JBQVdBLG1EQUFZQTtRQUh2QkE7O1dBRUdBO2FBQ0hBO1lBRUNFLE1BQU1BLENBQUNBLElBQUlBLENBQUNBLGFBQWFBLENBQUNBO1FBQzNCQSxDQUFDQTthQUVERixVQUF3QkEsS0FBY0E7WUFFckNFLElBQUlBLENBQUNBLGFBQWFBLENBQUNBLENBQUNBLEdBQUdBLEtBQUtBLENBQUNBLENBQUNBLENBQUNBO1lBQy9CQSxJQUFJQSxDQUFDQSxhQUFhQSxDQUFDQSxDQUFDQSxHQUFHQSxLQUFLQSxDQUFDQSxDQUFDQSxDQUFDQTtZQUMvQkEsSUFBSUEsQ0FBQ0EsYUFBYUEsQ0FBQ0EsQ0FBQ0EsR0FBR0EsS0FBS0EsQ0FBQ0EsQ0FBQ0EsQ0FBQ0E7WUFFL0JBLElBQUlBLENBQUNBLHNCQUFzQkEsRUFBRUEsQ0FBQ0E7UUFDL0JBLENBQUNBOzs7T0FUQUY7SUFxQkRBOztPQUVHQTtJQUNJQSxrREFBY0EsR0FBckJBLFVBQXNCQSxLQUFXQSxFQUFFQSxVQUF5QkEsRUFBRUEsb0JBQXlDQSxFQUFFQSxzQkFBNkNBLEVBQUVBLE1BQWFBO1FBRXBLRyxJQUFJQSxLQUFLQSxHQUFrQkEsc0JBQXNCQSxDQUFDQSxnQkFBZ0JBLENBQUNBLElBQUlBLENBQUNBLGVBQWVBLEVBQUVBLHlCQUF5QkEsQ0FBQ0Esa0JBQWtCQSxDQUFDQSxDQUFDQTtRQUV2SUEsRUFBRUEsQ0FBQ0EsQ0FBQ0EsSUFBSUEsQ0FBQ0EseUJBQXlCQSxDQUFDQSxJQUFJQSxJQUFJQSxzQkFBc0JBLENBQUNBLFlBQVlBLENBQUNBO1lBQzlFQSxvQkFBb0JBLENBQUNBLG9CQUFvQkEsQ0FBQ0EsS0FBS0EsRUFBRUEsSUFBSUEsQ0FBQ0EseUJBQXlCQSxDQUFDQSxZQUFZQSxFQUFFQSxLQUFLQSxFQUFFQSwyQkFBMkJBLENBQUNBLE9BQU9BLENBQUNBLENBQUNBO1FBQzNJQSxJQUFJQTtZQUNIQSxzQkFBc0JBLENBQUNBLGNBQWNBLENBQUNBLEtBQUtBLEVBQUVBLElBQUlBLENBQUNBLGlCQUFpQkEsQ0FBQ0EsQ0FBQ0EsRUFBRUEsSUFBSUEsQ0FBQ0EsaUJBQWlCQSxDQUFDQSxDQUFDQSxFQUFFQSxJQUFJQSxDQUFDQSxpQkFBaUJBLENBQUNBLENBQUNBLENBQUNBLENBQUNBO0lBQzdIQSxDQUFDQTtJQUVPSCwwREFBc0JBLEdBQTlCQTtRQUVDSSxFQUFFQSxDQUFDQSxDQUFDQSxJQUFJQSxDQUFDQSx5QkFBeUJBLENBQUNBLElBQUlBLElBQUlBLHNCQUFzQkEsQ0FBQ0EsTUFBTUEsQ0FBQ0E7WUFDeEVBLElBQUlBLENBQUNBLGlCQUFpQkEsR0FBR0EsSUFBSUEsUUFBUUEsQ0FBQ0EsSUFBSUEsQ0FBQ0EsYUFBYUEsQ0FBQ0EsQ0FBQ0EsR0FBQ0EsQ0FBQ0EsRUFBRUEsSUFBSUEsQ0FBQ0EsYUFBYUEsQ0FBQ0EsQ0FBQ0EsR0FBQ0EsQ0FBQ0EsRUFBRUEsSUFBSUEsQ0FBQ0EsYUFBYUEsQ0FBQ0EsQ0FBQ0EsR0FBQ0EsQ0FBQ0EsQ0FBQ0EsQ0FBQ0E7SUFDaEhBLENBQUNBO0lBbkRESixlQUFlQTtJQUNEQSw0Q0FBa0JBLEdBQWtCQSxDQUFDQSxDQUFDQTtJQW1EckRBLGdDQUFDQTtBQUFEQSxDQXREQSxBQXNEQ0EsRUF0RHVDLGlCQUFpQixFQXNEeEQ7QUFFRCxBQUFtQyxpQkFBMUIseUJBQXlCLENBQUMiLCJmaWxlIjoiYW5pbWF0b3JzL3N0YXRlcy9QYXJ0aWNsZUFjY2VsZXJhdGlvblN0YXRlLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2JiYXRlbWFuL1dlYnN0b3JtUHJvamVjdHMvYXdheWpzLXJlbmRlcmVyZ2wvIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFZlY3RvcjNEXHRcdFx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvY29yZS9nZW9tL1ZlY3RvcjNEXCIpO1xuaW1wb3J0IENhbWVyYVx0XHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLWNvcmUvbGliL2VudGl0aWVzL0NhbWVyYVwiKTtcblxuaW1wb3J0IEFuaW1hdGlvblJlZ2lzdGVyQ2FjaGVcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvYW5pbWF0b3JzL2RhdGEvQW5pbWF0aW9uUmVnaXN0ZXJDYWNoZVwiKTtcbmltcG9ydCBTdGFnZVx0XHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2NvcmUvYmFzZS9TdGFnZVwiKTtcbmltcG9ydCBSZW5kZXJhYmxlQmFzZVx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvY29yZS9wb29sL1JlbmRlcmFibGVCYXNlXCIpO1xuaW1wb3J0IENvbnRleHRHTFZlcnRleEJ1ZmZlckZvcm1hdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvY29yZS9zdGFnZWdsL0NvbnRleHRHTFZlcnRleEJ1ZmZlckZvcm1hdFwiKTtcblxuaW1wb3J0IFBhcnRpY2xlQW5pbWF0b3JcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXJlbmRlcmVyZ2wvbGliL2FuaW1hdG9ycy9QYXJ0aWNsZUFuaW1hdG9yXCIpO1xuaW1wb3J0IEFuaW1hdGlvblN1Ykdlb21ldHJ5XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL2RhdGEvQW5pbWF0aW9uU3ViR2VvbWV0cnlcIik7XG5pbXBvcnQgUGFydGljbGVQcm9wZXJ0aWVzTW9kZVx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvZGF0YS9QYXJ0aWNsZVByb3BlcnRpZXNNb2RlXCIpO1xuaW1wb3J0IFBhcnRpY2xlQWNjZWxlcmF0aW9uTm9kZVx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvbm9kZXMvUGFydGljbGVBY2NlbGVyYXRpb25Ob2RlXCIpO1xuaW1wb3J0IFBhcnRpY2xlU3RhdGVCYXNlXHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL3N0YXRlcy9QYXJ0aWNsZVN0YXRlQmFzZVwiKTtcblxuLyoqXG4gKiAuLi5cbiAqL1xuY2xhc3MgUGFydGljbGVBY2NlbGVyYXRpb25TdGF0ZSBleHRlbmRzIFBhcnRpY2xlU3RhdGVCYXNlXG57XG5cdC8qKiBAcHJpdmF0ZSAqL1xuXHRwdWJsaWMgc3RhdGljIEFDQ0VMRVJBVElPTl9JTkRFWDpudW1iZXIgLyppbnQqLyA9IDA7XG5cblx0cHJpdmF0ZSBfcGFydGljbGVBY2NlbGVyYXRpb25Ob2RlOlBhcnRpY2xlQWNjZWxlcmF0aW9uTm9kZTtcblx0cHJpdmF0ZSBfYWNjZWxlcmF0aW9uOlZlY3RvcjNEO1xuXHRwcml2YXRlIF9oYWxmQWNjZWxlcmF0aW9uOlZlY3RvcjNEO1xuXHRcblx0LyoqXG5cdCAqIERlZmluZXMgdGhlIGFjY2VsZXJhdGlvbiB2ZWN0b3Igb2YgdGhlIHN0YXRlLCB1c2VkIHdoZW4gaW4gZ2xvYmFsIG1vZGUuXG5cdCAqL1xuXHRwdWJsaWMgZ2V0IGFjY2VsZXJhdGlvbigpOlZlY3RvcjNEXG5cdHtcblx0XHRyZXR1cm4gdGhpcy5fYWNjZWxlcmF0aW9uO1xuXHR9XG5cdFxuXHRwdWJsaWMgc2V0IGFjY2VsZXJhdGlvbih2YWx1ZTpWZWN0b3IzRClcblx0e1xuXHRcdHRoaXMuX2FjY2VsZXJhdGlvbi54ID0gdmFsdWUueDtcblx0XHR0aGlzLl9hY2NlbGVyYXRpb24ueSA9IHZhbHVlLnk7XG5cdFx0dGhpcy5fYWNjZWxlcmF0aW9uLnogPSB2YWx1ZS56O1xuXG5cdFx0dGhpcy51cGRhdGVBY2NlbGVyYXRpb25EYXRhKCk7XG5cdH1cblx0XG5cdGNvbnN0cnVjdG9yKGFuaW1hdG9yOlBhcnRpY2xlQW5pbWF0b3IsIHBhcnRpY2xlQWNjZWxlcmF0aW9uTm9kZTpQYXJ0aWNsZUFjY2VsZXJhdGlvbk5vZGUpXG5cdHtcblx0XHRzdXBlcihhbmltYXRvciwgcGFydGljbGVBY2NlbGVyYXRpb25Ob2RlKTtcblxuXHRcdHRoaXMuX3BhcnRpY2xlQWNjZWxlcmF0aW9uTm9kZSA9IHBhcnRpY2xlQWNjZWxlcmF0aW9uTm9kZTtcblx0XHR0aGlzLl9hY2NlbGVyYXRpb24gPSB0aGlzLl9wYXJ0aWNsZUFjY2VsZXJhdGlvbk5vZGUuX2FjY2VsZXJhdGlvbjtcblxuXHRcdHRoaXMudXBkYXRlQWNjZWxlcmF0aW9uRGF0YSgpO1xuXHR9XG5cdFxuXHQvKipcblx0ICogQGluaGVyaXREb2Ncblx0ICovXG5cdHB1YmxpYyBzZXRSZW5kZXJTdGF0ZShzdGFnZTpTdGFnZSwgcmVuZGVyYWJsZTpSZW5kZXJhYmxlQmFzZSwgYW5pbWF0aW9uU3ViR2VvbWV0cnk6QW5pbWF0aW9uU3ViR2VvbWV0cnksIGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGU6QW5pbWF0aW9uUmVnaXN0ZXJDYWNoZSwgY2FtZXJhOkNhbWVyYSlcblx0e1xuXHRcdHZhciBpbmRleDpudW1iZXIgLyppbnQqLyA9IGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGUuZ2V0UmVnaXN0ZXJJbmRleCh0aGlzLl9wQW5pbWF0aW9uTm9kZSwgUGFydGljbGVBY2NlbGVyYXRpb25TdGF0ZS5BQ0NFTEVSQVRJT05fSU5ERVgpO1xuXHRcdFxuXHRcdGlmICh0aGlzLl9wYXJ0aWNsZUFjY2VsZXJhdGlvbk5vZGUubW9kZSA9PSBQYXJ0aWNsZVByb3BlcnRpZXNNb2RlLkxPQ0FMX1NUQVRJQylcblx0XHRcdGFuaW1hdGlvblN1Ykdlb21ldHJ5LmFjdGl2YXRlVmVydGV4QnVmZmVyKGluZGV4LCB0aGlzLl9wYXJ0aWNsZUFjY2VsZXJhdGlvbk5vZGUuX2lEYXRhT2Zmc2V0LCBzdGFnZSwgQ29udGV4dEdMVmVydGV4QnVmZmVyRm9ybWF0LkZMT0FUXzMpO1xuXHRcdGVsc2Vcblx0XHRcdGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGUuc2V0VmVydGV4Q29uc3QoaW5kZXgsIHRoaXMuX2hhbGZBY2NlbGVyYXRpb24ueCwgdGhpcy5faGFsZkFjY2VsZXJhdGlvbi55LCB0aGlzLl9oYWxmQWNjZWxlcmF0aW9uLnopO1xuXHR9XG5cdFxuXHRwcml2YXRlIHVwZGF0ZUFjY2VsZXJhdGlvbkRhdGEoKVxuXHR7XG5cdFx0aWYgKHRoaXMuX3BhcnRpY2xlQWNjZWxlcmF0aW9uTm9kZS5tb2RlID09IFBhcnRpY2xlUHJvcGVydGllc01vZGUuR0xPQkFMKVxuXHRcdFx0dGhpcy5faGFsZkFjY2VsZXJhdGlvbiA9IG5ldyBWZWN0b3IzRCh0aGlzLl9hY2NlbGVyYXRpb24ueC8yLCB0aGlzLl9hY2NlbGVyYXRpb24ueS8yLCB0aGlzLl9hY2NlbGVyYXRpb24uei8yKTtcblx0fVxufVxuXG5leHBvcnQgPSBQYXJ0aWNsZUFjY2VsZXJhdGlvblN0YXRlOyJdfQ==
\ No newline at end of file
diff --git a/lib/animators/states/ParticleAccelerationState.ts b/lib/animators/states/ParticleAccelerationState.ts
new file mode 100644
index 000000000..7a6a22516
--- /dev/null
+++ b/lib/animators/states/ParticleAccelerationState.ts
@@ -0,0 +1,74 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+
+import ParticleAnimator = require("awayjs-renderergl/lib/animators/ParticleAnimator");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleAccelerationNode = require("awayjs-renderergl/lib/animators/nodes/ParticleAccelerationNode");
+import ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+
+/**
+ * ...
+ */
+class ParticleAccelerationState extends ParticleStateBase
+{
+ /** @private */
+ public static ACCELERATION_INDEX:number /*int*/ = 0;
+
+ private _particleAccelerationNode:ParticleAccelerationNode;
+ private _acceleration:Vector3D;
+ private _halfAcceleration:Vector3D;
+
+ /**
+ * Defines the acceleration vector of the state, used when in global mode.
+ */
+ public get acceleration():Vector3D
+ {
+ return this._acceleration;
+ }
+
+ public set acceleration(value:Vector3D)
+ {
+ this._acceleration.x = value.x;
+ this._acceleration.y = value.y;
+ this._acceleration.z = value.z;
+
+ this.updateAccelerationData();
+ }
+
+ constructor(animator:ParticleAnimator, particleAccelerationNode:ParticleAccelerationNode)
+ {
+ super(animator, particleAccelerationNode);
+
+ this._particleAccelerationNode = particleAccelerationNode;
+ this._acceleration = this._particleAccelerationNode._acceleration;
+
+ this.updateAccelerationData();
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)
+ {
+ var index:number /*int*/ = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleAccelerationState.ACCELERATION_INDEX);
+
+ if (this._particleAccelerationNode.mode == ParticlePropertiesMode.LOCAL_STATIC)
+ animationSubGeometry.activateVertexBuffer(index, this._particleAccelerationNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ else
+ animationRegisterCache.setVertexConst(index, this._halfAcceleration.x, this._halfAcceleration.y, this._halfAcceleration.z);
+ }
+
+ private updateAccelerationData()
+ {
+ if (this._particleAccelerationNode.mode == ParticlePropertiesMode.GLOBAL)
+ this._halfAcceleration = new Vector3D(this._acceleration.x/2, this._acceleration.y/2, this._acceleration.z/2);
+ }
+}
+
+export = ParticleAccelerationState;
\ No newline at end of file
diff --git a/lib/animators/states/ParticleBezierCurveState.js b/lib/animators/states/ParticleBezierCurveState.js
new file mode 100755
index 000000000..05490c2c2
--- /dev/null
+++ b/lib/animators/states/ParticleBezierCurveState.js
@@ -0,0 +1,67 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+/**
+ * ...
+ */
+var ParticleBezierCurveState = (function (_super) {
+ __extends(ParticleBezierCurveState, _super);
+ function ParticleBezierCurveState(animator, particleBezierCurveNode) {
+ _super.call(this, animator, particleBezierCurveNode);
+ this._particleBezierCurveNode = particleBezierCurveNode;
+ this._controlPoint = this._particleBezierCurveNode._iControlPoint;
+ this._endPoint = this._particleBezierCurveNode._iEndPoint;
+ }
+ Object.defineProperty(ParticleBezierCurveState.prototype, "controlPoint", {
+ /**
+ * Defines the default control point of the node, used when in global mode.
+ */
+ get: function () {
+ return this._controlPoint;
+ },
+ set: function (value) {
+ this._controlPoint = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleBezierCurveState.prototype, "endPoint", {
+ /**
+ * Defines the default end point of the node, used when in global mode.
+ */
+ get: function () {
+ return this._endPoint;
+ },
+ set: function (value) {
+ this._endPoint = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ ParticleBezierCurveState.prototype.setRenderState = function (stage, renderable, animationSubGeometry, animationRegisterCache, camera) {
+ var controlIndex = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleBezierCurveState.BEZIER_CONTROL_INDEX);
+ var endIndex = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleBezierCurveState.BEZIER_END_INDEX);
+ if (this._particleBezierCurveNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {
+ animationSubGeometry.activateVertexBuffer(controlIndex, this._particleBezierCurveNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ animationSubGeometry.activateVertexBuffer(endIndex, this._particleBezierCurveNode._iDataOffset + 3, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ }
+ else {
+ animationRegisterCache.setVertexConst(controlIndex, this._controlPoint.x, this._controlPoint.y, this._controlPoint.z);
+ animationRegisterCache.setVertexConst(endIndex, this._endPoint.x, this._endPoint.y, this._endPoint.z);
+ }
+ };
+ /** @private */
+ ParticleBezierCurveState.BEZIER_CONTROL_INDEX = 0;
+ /** @private */
+ ParticleBezierCurveState.BEZIER_END_INDEX = 1;
+ return ParticleBezierCurveState;
+})(ParticleStateBase);
+module.exports = ParticleBezierCurveState;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9zdGF0ZXMvcGFydGljbGViZXppZXJjdXJ2ZXN0YXRlLnRzIl0sIm5hbWVzIjpbIlBhcnRpY2xlQmV6aWVyQ3VydmVTdGF0ZSIsIlBhcnRpY2xlQmV6aWVyQ3VydmVTdGF0ZS5jb25zdHJ1Y3RvciIsIlBhcnRpY2xlQmV6aWVyQ3VydmVTdGF0ZS5jb250cm9sUG9pbnQiLCJQYXJ0aWNsZUJlemllckN1cnZlU3RhdGUuZW5kUG9pbnQiLCJQYXJ0aWNsZUJlemllckN1cnZlU3RhdGUuc2V0UmVuZGVyU3RhdGUiXSwibWFwcGluZ3MiOiI7Ozs7OztBQU1BLElBQU8sMkJBQTJCLFdBQVksNkRBQTZELENBQUMsQ0FBQztBQUk3RyxJQUFPLHNCQUFzQixXQUFhLDZEQUE2RCxDQUFDLENBQUM7QUFFekcsSUFBTyxpQkFBaUIsV0FBYywwREFBMEQsQ0FBQyxDQUFDO0FBRWxHLEFBR0E7O0dBREc7SUFDRyx3QkFBd0I7SUFBU0EsVUFBakNBLHdCQUF3QkEsVUFBMEJBO0lBc0N2REEsU0F0Q0tBLHdCQUF3QkEsQ0FzQ2pCQSxRQUF5QkEsRUFBRUEsdUJBQStDQTtRQUVyRkMsa0JBQU1BLFFBQVFBLEVBQUVBLHVCQUF1QkEsQ0FBQ0EsQ0FBQ0E7UUFFekNBLElBQUlBLENBQUNBLHdCQUF3QkEsR0FBR0EsdUJBQXVCQSxDQUFDQTtRQUN4REEsSUFBSUEsQ0FBQ0EsYUFBYUEsR0FBR0EsSUFBSUEsQ0FBQ0Esd0JBQXdCQSxDQUFDQSxjQUFjQSxDQUFDQTtRQUNsRUEsSUFBSUEsQ0FBQ0EsU0FBU0EsR0FBR0EsSUFBSUEsQ0FBQ0Esd0JBQXdCQSxDQUFDQSxVQUFVQSxDQUFDQTtJQUMzREEsQ0FBQ0E7SUE5QkRELHNCQUFXQSxrREFBWUE7UUFIdkJBOztXQUVHQTthQUNIQTtZQUVDRSxNQUFNQSxDQUFDQSxJQUFJQSxDQUFDQSxhQUFhQSxDQUFDQTtRQUMzQkEsQ0FBQ0E7YUFFREYsVUFBd0JBLEtBQWNBO1lBRXJDRSxJQUFJQSxDQUFDQSxhQUFhQSxHQUFHQSxLQUFLQSxDQUFDQTtRQUM1QkEsQ0FBQ0E7OztPQUxBRjtJQVVEQSxzQkFBV0EsOENBQVFBO1FBSG5CQTs7V0FFR0E7YUFDSEE7WUFFQ0csTUFBTUEsQ0FBQ0EsSUFBSUEsQ0FBQ0EsU0FBU0EsQ0FBQ0E7UUFDdkJBLENBQUNBO2FBRURILFVBQW9CQSxLQUFjQTtZQUVqQ0csSUFBSUEsQ0FBQ0EsU0FBU0EsR0FBR0EsS0FBS0EsQ0FBQ0E7UUFDeEJBLENBQUNBOzs7T0FMQUg7SUFnQk1BLGlEQUFjQSxHQUFyQkEsVUFBc0JBLEtBQVdBLEVBQUVBLFVBQXlCQSxFQUFFQSxvQkFBeUNBLEVBQUVBLHNCQUE2Q0EsRUFBRUEsTUFBYUE7UUFFcEtJLElBQUlBLFlBQVlBLEdBQWtCQSxzQkFBc0JBLENBQUNBLGdCQUFnQkEsQ0FBQ0EsSUFBSUEsQ0FBQ0EsZUFBZUEsRUFBRUEsd0JBQXdCQSxDQUFDQSxvQkFBb0JBLENBQUNBLENBQUNBO1FBQy9JQSxJQUFJQSxRQUFRQSxHQUFrQkEsc0JBQXNCQSxDQUFDQSxnQkFBZ0JBLENBQUNBLElBQUlBLENBQUNBLGVBQWVBLEVBQUVBLHdCQUF3QkEsQ0FBQ0EsZ0JBQWdCQSxDQUFDQSxDQUFDQTtRQUV2SUEsRUFBRUEsQ0FBQ0EsQ0FBQ0EsSUFBSUEsQ0FBQ0Esd0JBQXdCQSxDQUFDQSxJQUFJQSxJQUFJQSxzQkFBc0JBLENBQUNBLFlBQVlBLENBQUNBLENBQUNBLENBQUNBO1lBQy9FQSxvQkFBb0JBLENBQUNBLG9CQUFvQkEsQ0FBQ0EsWUFBWUEsRUFBRUEsSUFBSUEsQ0FBQ0Esd0JBQXdCQSxDQUFDQSxZQUFZQSxFQUFFQSxLQUFLQSxFQUFFQSwyQkFBMkJBLENBQUNBLE9BQU9BLENBQUNBLENBQUNBO1lBQ2hKQSxvQkFBb0JBLENBQUNBLG9CQUFvQkEsQ0FBQ0EsUUFBUUEsRUFBRUEsSUFBSUEsQ0FBQ0Esd0JBQXdCQSxDQUFDQSxZQUFZQSxHQUFHQSxDQUFDQSxFQUFFQSxLQUFLQSxFQUFFQSwyQkFBMkJBLENBQUNBLE9BQU9BLENBQUNBLENBQUNBO1FBQ2pKQSxDQUFDQTtRQUFDQSxJQUFJQSxDQUFDQSxDQUFDQTtZQUNQQSxzQkFBc0JBLENBQUNBLGNBQWNBLENBQUNBLFlBQVlBLEVBQUVBLElBQUlBLENBQUNBLGFBQWFBLENBQUNBLENBQUNBLEVBQUVBLElBQUlBLENBQUNBLGFBQWFBLENBQUNBLENBQUNBLEVBQUVBLElBQUlBLENBQUNBLGFBQWFBLENBQUNBLENBQUNBLENBQUNBLENBQUNBO1lBQ3RIQSxzQkFBc0JBLENBQUNBLGNBQWNBLENBQUNBLFFBQVFBLEVBQUVBLElBQUlBLENBQUNBLFNBQVNBLENBQUNBLENBQUNBLEVBQUVBLElBQUlBLENBQUNBLFNBQVNBLENBQUNBLENBQUNBLEVBQUVBLElBQUlBLENBQUNBLFNBQVNBLENBQUNBLENBQUNBLENBQUNBLENBQUNBO1FBQ3ZHQSxDQUFDQTtJQUNGQSxDQUFDQTtJQXpEREosZUFBZUE7SUFDREEsNkNBQW9CQSxHQUFrQkEsQ0FBQ0EsQ0FBQ0E7SUFFdERBLGVBQWVBO0lBQ0RBLHlDQUFnQkEsR0FBa0JBLENBQUNBLENBQUNBO0lBc0RuREEsK0JBQUNBO0FBQURBLENBNURBLEFBNERDQSxFQTVEc0MsaUJBQWlCLEVBNER2RDtBQUVELEFBQWtDLGlCQUF6Qix3QkFBd0IsQ0FBQyIsImZpbGUiOiJhbmltYXRvcnMvc3RhdGVzL1BhcnRpY2xlQmV6aWVyQ3VydmVTdGF0ZS5qcyIsInNvdXJjZVJvb3QiOiIvVXNlcnMvcm9iYmF0ZW1hbi9XZWJzdG9ybVByb2plY3RzL2F3YXlqcy1yZW5kZXJlcmdsLyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBWZWN0b3IzRFx0XHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLWNvcmUvbGliL2NvcmUvZ2VvbS9WZWN0b3IzRFwiKTtcbmltcG9ydCBDYW1lcmFcdFx0XHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1jb3JlL2xpYi9lbnRpdGllcy9DYW1lcmFcIik7XG5cbmltcG9ydCBBbmltYXRpb25SZWdpc3RlckNhY2hlXHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2FuaW1hdG9ycy9kYXRhL0FuaW1hdGlvblJlZ2lzdGVyQ2FjaGVcIik7XG5pbXBvcnQgU3RhZ2VcdFx0XHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1zdGFnZWdsL2xpYi9jb3JlL2Jhc2UvU3RhZ2VcIik7XG5pbXBvcnQgUmVuZGVyYWJsZUJhc2VcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2NvcmUvcG9vbC9SZW5kZXJhYmxlQmFzZVwiKTtcbmltcG9ydCBDb250ZXh0R0xWZXJ0ZXhCdWZmZXJGb3JtYXRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2NvcmUvc3RhZ2VnbC9Db250ZXh0R0xWZXJ0ZXhCdWZmZXJGb3JtYXRcIik7XG5cbmltcG9ydCBQYXJ0aWNsZUFuaW1hdG9yXHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvUGFydGljbGVBbmltYXRvclwiKTtcbmltcG9ydCBBbmltYXRpb25TdWJHZW9tZXRyeVx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXJlbmRlcmVyZ2wvbGliL2FuaW1hdG9ycy9kYXRhL0FuaW1hdGlvblN1Ykdlb21ldHJ5XCIpO1xuaW1wb3J0IFBhcnRpY2xlUHJvcGVydGllc01vZGVcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL2RhdGEvUGFydGljbGVQcm9wZXJ0aWVzTW9kZVwiKTtcbmltcG9ydCBQYXJ0aWNsZUJlemllckN1cnZlTm9kZVx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvbm9kZXMvUGFydGljbGVCZXppZXJDdXJ2ZU5vZGVcIik7XG5pbXBvcnQgUGFydGljbGVTdGF0ZUJhc2VcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvc3RhdGVzL1BhcnRpY2xlU3RhdGVCYXNlXCIpO1xuXG4vKipcbiAqIC4uLlxuICovXG5jbGFzcyBQYXJ0aWNsZUJlemllckN1cnZlU3RhdGUgZXh0ZW5kcyBQYXJ0aWNsZVN0YXRlQmFzZVxue1xuXHQvKiogQHByaXZhdGUgKi9cblx0cHVibGljIHN0YXRpYyBCRVpJRVJfQ09OVFJPTF9JTkRFWDpudW1iZXIgLyppbnQqLyA9IDA7XG5cblx0LyoqIEBwcml2YXRlICovXG5cdHB1YmxpYyBzdGF0aWMgQkVaSUVSX0VORF9JTkRFWDpudW1iZXIgLyppbnQqLyA9IDE7XG5cblx0cHJpdmF0ZSBfcGFydGljbGVCZXppZXJDdXJ2ZU5vZGU6UGFydGljbGVCZXppZXJDdXJ2ZU5vZGU7XG5cdHByaXZhdGUgX2NvbnRyb2xQb2ludDpWZWN0b3IzRDtcblx0cHJpdmF0ZSBfZW5kUG9pbnQ6VmVjdG9yM0Q7XG5cblx0LyoqXG5cdCAqIERlZmluZXMgdGhlIGRlZmF1bHQgY29udHJvbCBwb2ludCBvZiB0aGUgbm9kZSwgdXNlZCB3aGVuIGluIGdsb2JhbCBtb2RlLlxuXHQgKi9cblx0cHVibGljIGdldCBjb250cm9sUG9pbnQoKTpWZWN0b3IzRFxuXHR7XG5cdFx0cmV0dXJuIHRoaXMuX2NvbnRyb2xQb2ludDtcblx0fVxuXG5cdHB1YmxpYyBzZXQgY29udHJvbFBvaW50KHZhbHVlOlZlY3RvcjNEKVxuXHR7XG5cdFx0dGhpcy5fY29udHJvbFBvaW50ID0gdmFsdWU7XG5cdH1cblxuXHQvKipcblx0ICogRGVmaW5lcyB0aGUgZGVmYXVsdCBlbmQgcG9pbnQgb2YgdGhlIG5vZGUsIHVzZWQgd2hlbiBpbiBnbG9iYWwgbW9kZS5cblx0ICovXG5cdHB1YmxpYyBnZXQgZW5kUG9pbnQoKTpWZWN0b3IzRFxuXHR7XG5cdFx0cmV0dXJuIHRoaXMuX2VuZFBvaW50O1xuXHR9XG5cblx0cHVibGljIHNldCBlbmRQb2ludCh2YWx1ZTpWZWN0b3IzRClcblx0e1xuXHRcdHRoaXMuX2VuZFBvaW50ID0gdmFsdWU7XG5cdH1cblxuXHRjb25zdHJ1Y3RvcihhbmltYXRvcjpQYXJ0aWNsZUFuaW1hdG9yLCBwYXJ0aWNsZUJlemllckN1cnZlTm9kZTpQYXJ0aWNsZUJlemllckN1cnZlTm9kZSlcblx0e1xuXHRcdHN1cGVyKGFuaW1hdG9yLCBwYXJ0aWNsZUJlemllckN1cnZlTm9kZSk7XG5cblx0XHR0aGlzLl9wYXJ0aWNsZUJlemllckN1cnZlTm9kZSA9IHBhcnRpY2xlQmV6aWVyQ3VydmVOb2RlO1xuXHRcdHRoaXMuX2NvbnRyb2xQb2ludCA9IHRoaXMuX3BhcnRpY2xlQmV6aWVyQ3VydmVOb2RlLl9pQ29udHJvbFBvaW50O1xuXHRcdHRoaXMuX2VuZFBvaW50ID0gdGhpcy5fcGFydGljbGVCZXppZXJDdXJ2ZU5vZGUuX2lFbmRQb2ludDtcblx0fVxuXG5cdHB1YmxpYyBzZXRSZW5kZXJTdGF0ZShzdGFnZTpTdGFnZSwgcmVuZGVyYWJsZTpSZW5kZXJhYmxlQmFzZSwgYW5pbWF0aW9uU3ViR2VvbWV0cnk6QW5pbWF0aW9uU3ViR2VvbWV0cnksIGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGU6QW5pbWF0aW9uUmVnaXN0ZXJDYWNoZSwgY2FtZXJhOkNhbWVyYSlcblx0e1xuXHRcdHZhciBjb250cm9sSW5kZXg6bnVtYmVyIC8qaW50Ki8gPSBhbmltYXRpb25SZWdpc3RlckNhY2hlLmdldFJlZ2lzdGVySW5kZXgodGhpcy5fcEFuaW1hdGlvbk5vZGUsIFBhcnRpY2xlQmV6aWVyQ3VydmVTdGF0ZS5CRVpJRVJfQ09OVFJPTF9JTkRFWCk7XG5cdFx0dmFyIGVuZEluZGV4Om51bWJlciAvKmludCovID0gYW5pbWF0aW9uUmVnaXN0ZXJDYWNoZS5nZXRSZWdpc3RlckluZGV4KHRoaXMuX3BBbmltYXRpb25Ob2RlLCBQYXJ0aWNsZUJlemllckN1cnZlU3RhdGUuQkVaSUVSX0VORF9JTkRFWCk7XG5cblx0XHRpZiAodGhpcy5fcGFydGljbGVCZXppZXJDdXJ2ZU5vZGUubW9kZSA9PSBQYXJ0aWNsZVByb3BlcnRpZXNNb2RlLkxPQ0FMX1NUQVRJQykge1xuXHRcdFx0YW5pbWF0aW9uU3ViR2VvbWV0cnkuYWN0aXZhdGVWZXJ0ZXhCdWZmZXIoY29udHJvbEluZGV4LCB0aGlzLl9wYXJ0aWNsZUJlemllckN1cnZlTm9kZS5faURhdGFPZmZzZXQsIHN0YWdlLCBDb250ZXh0R0xWZXJ0ZXhCdWZmZXJGb3JtYXQuRkxPQVRfMyk7XG5cdFx0XHRhbmltYXRpb25TdWJHZW9tZXRyeS5hY3RpdmF0ZVZlcnRleEJ1ZmZlcihlbmRJbmRleCwgdGhpcy5fcGFydGljbGVCZXppZXJDdXJ2ZU5vZGUuX2lEYXRhT2Zmc2V0ICsgMywgc3RhZ2UsIENvbnRleHRHTFZlcnRleEJ1ZmZlckZvcm1hdC5GTE9BVF8zKTtcblx0XHR9IGVsc2Uge1xuXHRcdFx0YW5pbWF0aW9uUmVnaXN0ZXJDYWNoZS5zZXRWZXJ0ZXhDb25zdChjb250cm9sSW5kZXgsIHRoaXMuX2NvbnRyb2xQb2ludC54LCB0aGlzLl9jb250cm9sUG9pbnQueSwgdGhpcy5fY29udHJvbFBvaW50LnopO1xuXHRcdFx0YW5pbWF0aW9uUmVnaXN0ZXJDYWNoZS5zZXRWZXJ0ZXhDb25zdChlbmRJbmRleCwgdGhpcy5fZW5kUG9pbnQueCwgdGhpcy5fZW5kUG9pbnQueSwgdGhpcy5fZW5kUG9pbnQueik7XG5cdFx0fVxuXHR9XG59XG5cbmV4cG9ydCA9IFBhcnRpY2xlQmV6aWVyQ3VydmVTdGF0ZTsiXX0=
\ No newline at end of file
diff --git a/lib/animators/states/ParticleBezierCurveState.ts b/lib/animators/states/ParticleBezierCurveState.ts
new file mode 100644
index 000000000..9dbb47880
--- /dev/null
+++ b/lib/animators/states/ParticleBezierCurveState.ts
@@ -0,0 +1,80 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+
+import ParticleAnimator = require("awayjs-renderergl/lib/animators/ParticleAnimator");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleBezierCurveNode = require("awayjs-renderergl/lib/animators/nodes/ParticleBezierCurveNode");
+import ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+
+/**
+ * ...
+ */
+class ParticleBezierCurveState extends ParticleStateBase
+{
+ /** @private */
+ public static BEZIER_CONTROL_INDEX:number /*int*/ = 0;
+
+ /** @private */
+ public static BEZIER_END_INDEX:number /*int*/ = 1;
+
+ private _particleBezierCurveNode:ParticleBezierCurveNode;
+ private _controlPoint:Vector3D;
+ private _endPoint:Vector3D;
+
+ /**
+ * Defines the default control point of the node, used when in global mode.
+ */
+ public get controlPoint():Vector3D
+ {
+ return this._controlPoint;
+ }
+
+ public set controlPoint(value:Vector3D)
+ {
+ this._controlPoint = value;
+ }
+
+ /**
+ * Defines the default end point of the node, used when in global mode.
+ */
+ public get endPoint():Vector3D
+ {
+ return this._endPoint;
+ }
+
+ public set endPoint(value:Vector3D)
+ {
+ this._endPoint = value;
+ }
+
+ constructor(animator:ParticleAnimator, particleBezierCurveNode:ParticleBezierCurveNode)
+ {
+ super(animator, particleBezierCurveNode);
+
+ this._particleBezierCurveNode = particleBezierCurveNode;
+ this._controlPoint = this._particleBezierCurveNode._iControlPoint;
+ this._endPoint = this._particleBezierCurveNode._iEndPoint;
+ }
+
+ public setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)
+ {
+ var controlIndex:number /*int*/ = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleBezierCurveState.BEZIER_CONTROL_INDEX);
+ var endIndex:number /*int*/ = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleBezierCurveState.BEZIER_END_INDEX);
+
+ if (this._particleBezierCurveNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {
+ animationSubGeometry.activateVertexBuffer(controlIndex, this._particleBezierCurveNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ animationSubGeometry.activateVertexBuffer(endIndex, this._particleBezierCurveNode._iDataOffset + 3, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ } else {
+ animationRegisterCache.setVertexConst(controlIndex, this._controlPoint.x, this._controlPoint.y, this._controlPoint.z);
+ animationRegisterCache.setVertexConst(endIndex, this._endPoint.x, this._endPoint.y, this._endPoint.z);
+ }
+ }
+}
+
+export = ParticleBezierCurveState;
\ No newline at end of file
diff --git a/lib/animators/states/ParticleBillboardState.js b/lib/animators/states/ParticleBillboardState.js
new file mode 100755
index 000000000..58d8af9cc
--- /dev/null
+++ b/lib/animators/states/ParticleBillboardState.js
@@ -0,0 +1,76 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var MathConsts = require("awayjs-core/lib/core/geom/MathConsts");
+var Matrix3D = require("awayjs-core/lib/core/geom/Matrix3D");
+var Orientation3D = require("awayjs-core/lib/core/geom/Orientation3D");
+var ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+/**
+ * ...
+ */
+var ParticleBillboardState = (function (_super) {
+ __extends(ParticleBillboardState, _super);
+ /**
+ *
+ */
+ function ParticleBillboardState(animator, particleNode) {
+ _super.call(this, animator, particleNode);
+ this._matrix = new Matrix3D;
+ this._billboardAxis = particleNode._iBillboardAxis;
+ }
+ ParticleBillboardState.prototype.setRenderState = function (stage, renderable, animationSubGeometry, animationRegisterCache, camera) {
+ var comps;
+ if (this._billboardAxis) {
+ var pos = renderable.sourceEntity.sceneTransform.position;
+ var look = camera.sceneTransform.position.subtract(pos);
+ var right = look.crossProduct(this._billboardAxis);
+ right.normalize();
+ look = this.billboardAxis.crossProduct(right);
+ look.normalize();
+ //create a quick inverse projection matrix
+ this._matrix.copyFrom(renderable.sourceEntity.sceneTransform);
+ comps = this._matrix.decompose(Orientation3D.AXIS_ANGLE);
+ this._matrix.copyColumnFrom(0, right);
+ this._matrix.copyColumnFrom(1, this.billboardAxis);
+ this._matrix.copyColumnFrom(2, look);
+ this._matrix.copyColumnFrom(3, pos);
+ this._matrix.appendRotation(-comps[1].w * MathConsts.RADIANS_TO_DEGREES, comps[1]);
+ }
+ else {
+ //create a quick inverse projection matrix
+ this._matrix.copyFrom(renderable.sourceEntity.sceneTransform);
+ this._matrix.append(camera.inverseSceneTransform);
+ //decompose using axis angle rotations
+ comps = this._matrix.decompose(Orientation3D.AXIS_ANGLE);
+ //recreate the matrix with just the rotation data
+ this._matrix.identity();
+ this._matrix.appendRotation(-comps[1].w * MathConsts.RADIANS_TO_DEGREES, comps[1]);
+ }
+ //set a new matrix transform constant
+ animationRegisterCache.setVertexConstFromMatrix(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleBillboardState.MATRIX_INDEX), this._matrix);
+ };
+ Object.defineProperty(ParticleBillboardState.prototype, "billboardAxis", {
+ /**
+ * Defines the billboard axis.
+ */
+ get: function () {
+ return this.billboardAxis;
+ },
+ set: function (value) {
+ this.billboardAxis = value ? value.clone() : null;
+ if (this.billboardAxis)
+ this.billboardAxis.normalize();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /** @private */
+ ParticleBillboardState.MATRIX_INDEX = 0;
+ return ParticleBillboardState;
+})(ParticleStateBase);
+module.exports = ParticleBillboardState;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/states/particlebillboardstate.ts"],"names":["ParticleBillboardState","ParticleBillboardState.constructor","ParticleBillboardState.setRenderState","ParticleBillboardState.billboardAxis"],"mappings":"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","file":"animators/states/ParticleBillboardState.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import MathConsts\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/MathConsts\");\nimport Matrix3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Matrix3D\");\nimport Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\nimport Orientation3D\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Orientation3D\");\nimport Camera\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Camera\");\n\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport RenderableBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/RenderableBase\");\nimport ContextGLVertexBufferFormat\t\t= require(\"awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat\");\n\nimport ParticleAnimator\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimator\");\nimport AnimationSubGeometry\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/AnimationSubGeometry\");\nimport ParticleBillboardNode\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleBillboardNode\");\nimport ParticleStateBase\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleStateBase\");\n\n/**\n * ...\n */\nclass ParticleBillboardState extends ParticleStateBase\n{\n\t/** @private */\n\tpublic static MATRIX_INDEX:number /*int*/ = 0;\n\n\tprivate _matrix:Matrix3D = new Matrix3D;\n\n\tprivate _billboardAxis:Vector3D;\n\n\t/**\n\t *\n\t */\n\tconstructor(animator:ParticleAnimator, particleNode:ParticleBillboardNode)\n\t{\n\t\tsuper(animator, particleNode);\n\n\t\tthis._billboardAxis = particleNode._iBillboardAxis;\n\t}\n\n\tpublic setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)\n\t{\n\t\tvar comps:Array<Vector3D>;\n\t\tif (this._billboardAxis) {\n\t\t\tvar pos:Vector3D = renderable.sourceEntity.sceneTransform.position;\n\t\t\tvar look:Vector3D = camera.sceneTransform.position.subtract(pos);\n\t\t\tvar right:Vector3D = look.crossProduct(this._billboardAxis);\n\t\t\tright.normalize();\n\t\t\tlook = this.billboardAxis.crossProduct(right);\n\t\t\tlook.normalize();\n\n\t\t\t//create a quick inverse projection matrix\n\t\t\tthis._matrix.copyFrom(renderable.sourceEntity.sceneTransform);\n\t\t\tcomps = this._matrix.decompose(Orientation3D.AXIS_ANGLE);\n\t\t\tthis._matrix.copyColumnFrom(0, right);\n\t\t\tthis._matrix.copyColumnFrom(1, this.billboardAxis);\n\t\t\tthis._matrix.copyColumnFrom(2, look);\n\t\t\tthis._matrix.copyColumnFrom(3, pos);\n\t\t\tthis._matrix.appendRotation(-comps[1].w*MathConsts.RADIANS_TO_DEGREES, comps[1]);\n\t\t} else {\n\t\t\t//create a quick inverse projection matrix\n\t\t\tthis._matrix.copyFrom(renderable.sourceEntity.sceneTransform);\n\t\t\tthis._matrix.append(camera.inverseSceneTransform);\n\n\t\t\t//decompose using axis angle rotations\n\t\t\tcomps = this._matrix.decompose(Orientation3D.AXIS_ANGLE);\n\n\t\t\t//recreate the matrix with just the rotation data\n\t\t\tthis._matrix.identity();\n\t\t\tthis._matrix.appendRotation(-comps[1].w*MathConsts.RADIANS_TO_DEGREES, comps[1]);\n\t\t}\n\n\t\t//set a new matrix transform constant\n\t\tanimationRegisterCache.setVertexConstFromMatrix(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleBillboardState.MATRIX_INDEX), this._matrix);\n\t}\n\n\t/**\n\t * Defines the billboard axis.\n\t */\n\tpublic get billboardAxis():Vector3D\n\t{\n\t\treturn this.billboardAxis;\n\t}\n\n\tpublic set billboardAxis(value:Vector3D)\n\t{\n\t\tthis.billboardAxis = value? value.clone() : null;\n\t\tif (this.billboardAxis)\n\t\t\tthis.billboardAxis.normalize();\n\t}\n\n}\n\nexport = ParticleBillboardState;"]}
\ No newline at end of file
diff --git a/lib/animators/states/ParticleBillboardState.ts b/lib/animators/states/ParticleBillboardState.ts
new file mode 100644
index 000000000..12532272f
--- /dev/null
+++ b/lib/animators/states/ParticleBillboardState.ts
@@ -0,0 +1,92 @@
+import MathConsts = require("awayjs-core/lib/core/geom/MathConsts");
+import Matrix3D = require("awayjs-core/lib/core/geom/Matrix3D");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import Orientation3D = require("awayjs-core/lib/core/geom/Orientation3D");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+
+import ParticleAnimator = require("awayjs-renderergl/lib/animators/ParticleAnimator");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticleBillboardNode = require("awayjs-renderergl/lib/animators/nodes/ParticleBillboardNode");
+import ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+
+/**
+ * ...
+ */
+class ParticleBillboardState extends ParticleStateBase
+{
+ /** @private */
+ public static MATRIX_INDEX:number /*int*/ = 0;
+
+ private _matrix:Matrix3D = new Matrix3D;
+
+ private _billboardAxis:Vector3D;
+
+ /**
+ *
+ */
+ constructor(animator:ParticleAnimator, particleNode:ParticleBillboardNode)
+ {
+ super(animator, particleNode);
+
+ this._billboardAxis = particleNode._iBillboardAxis;
+ }
+
+ public setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)
+ {
+ var comps:Array;
+ if (this._billboardAxis) {
+ var pos:Vector3D = renderable.sourceEntity.sceneTransform.position;
+ var look:Vector3D = camera.sceneTransform.position.subtract(pos);
+ var right:Vector3D = look.crossProduct(this._billboardAxis);
+ right.normalize();
+ look = this.billboardAxis.crossProduct(right);
+ look.normalize();
+
+ //create a quick inverse projection matrix
+ this._matrix.copyFrom(renderable.sourceEntity.sceneTransform);
+ comps = this._matrix.decompose(Orientation3D.AXIS_ANGLE);
+ this._matrix.copyColumnFrom(0, right);
+ this._matrix.copyColumnFrom(1, this.billboardAxis);
+ this._matrix.copyColumnFrom(2, look);
+ this._matrix.copyColumnFrom(3, pos);
+ this._matrix.appendRotation(-comps[1].w*MathConsts.RADIANS_TO_DEGREES, comps[1]);
+ } else {
+ //create a quick inverse projection matrix
+ this._matrix.copyFrom(renderable.sourceEntity.sceneTransform);
+ this._matrix.append(camera.inverseSceneTransform);
+
+ //decompose using axis angle rotations
+ comps = this._matrix.decompose(Orientation3D.AXIS_ANGLE);
+
+ //recreate the matrix with just the rotation data
+ this._matrix.identity();
+ this._matrix.appendRotation(-comps[1].w*MathConsts.RADIANS_TO_DEGREES, comps[1]);
+ }
+
+ //set a new matrix transform constant
+ animationRegisterCache.setVertexConstFromMatrix(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleBillboardState.MATRIX_INDEX), this._matrix);
+ }
+
+ /**
+ * Defines the billboard axis.
+ */
+ public get billboardAxis():Vector3D
+ {
+ return this.billboardAxis;
+ }
+
+ public set billboardAxis(value:Vector3D)
+ {
+ this.billboardAxis = value? value.clone() : null;
+ if (this.billboardAxis)
+ this.billboardAxis.normalize();
+ }
+
+}
+
+export = ParticleBillboardState;
\ No newline at end of file
diff --git a/lib/animators/states/ParticleColorState.js b/lib/animators/states/ParticleColorState.js
new file mode 100755
index 000000000..ca0e7cac3
--- /dev/null
+++ b/lib/animators/states/ParticleColorState.js
@@ -0,0 +1,160 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+/**
+ * ...
+ * @author ...
+ */
+var ParticleColorState = (function (_super) {
+ __extends(ParticleColorState, _super);
+ function ParticleColorState(animator, particleColorNode) {
+ _super.call(this, animator, particleColorNode);
+ this._particleColorNode = particleColorNode;
+ this._usesMultiplier = this._particleColorNode._iUsesMultiplier;
+ this._usesOffset = this._particleColorNode._iUsesOffset;
+ this._usesCycle = this._particleColorNode._iUsesCycle;
+ this._usesPhase = this._particleColorNode._iUsesPhase;
+ this._startColor = this._particleColorNode._iStartColor;
+ this._endColor = this._particleColorNode._iEndColor;
+ this._cycleDuration = this._particleColorNode._iCycleDuration;
+ this._cyclePhase = this._particleColorNode._iCyclePhase;
+ this.updateColorData();
+ }
+ Object.defineProperty(ParticleColorState.prototype, "startColor", {
+ /**
+ * Defines the start color transform of the state, when in global mode.
+ */
+ get: function () {
+ return this._startColor;
+ },
+ set: function (value) {
+ this._startColor = value;
+ this.updateColorData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleColorState.prototype, "endColor", {
+ /**
+ * Defines the end color transform of the state, when in global mode.
+ */
+ get: function () {
+ return this._endColor;
+ },
+ set: function (value) {
+ this._endColor = value;
+ this.updateColorData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleColorState.prototype, "cycleDuration", {
+ /**
+ * Defines the duration of the animation in seconds, used as a period independent of particle duration when in global mode. Defaults to 1.
+ */
+ get: function () {
+ return this._cycleDuration;
+ },
+ set: function (value) {
+ this._cycleDuration = value;
+ this.updateColorData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleColorState.prototype, "cyclePhase", {
+ /**
+ * Defines the phase of the cycle in degrees, used as the starting offset of the cycle when in global mode. Defaults to 0.
+ */
+ get: function () {
+ return this._cyclePhase;
+ },
+ set: function (value) {
+ this._cyclePhase = value;
+ this.updateColorData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ ParticleColorState.prototype.setRenderState = function (stage, renderable, animationSubGeometry, animationRegisterCache, camera) {
+ if (animationRegisterCache.needFragmentAnimation) {
+ var dataOffset = this._particleColorNode._iDataOffset;
+ if (this._usesCycle)
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.CYCLE_INDEX), this._cycleData.x, this._cycleData.y, this._cycleData.z, this._cycleData.w);
+ if (this._usesMultiplier) {
+ if (this._particleColorNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.START_MULTIPLIER_INDEX), dataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ dataOffset += 4;
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.DELTA_MULTIPLIER_INDEX), dataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ dataOffset += 4;
+ }
+ else {
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.START_MULTIPLIER_INDEX), this._startMultiplierData.x, this._startMultiplierData.y, this._startMultiplierData.z, this._startMultiplierData.w);
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.DELTA_MULTIPLIER_INDEX), this._deltaMultiplierData.x, this._deltaMultiplierData.y, this._deltaMultiplierData.z, this._deltaMultiplierData.w);
+ }
+ }
+ if (this._usesOffset) {
+ if (this._particleColorNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.START_OFFSET_INDEX), dataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ dataOffset += 4;
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.DELTA_OFFSET_INDEX), dataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ dataOffset += 4;
+ }
+ else {
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.START_OFFSET_INDEX), this._startOffsetData.x, this._startOffsetData.y, this._startOffsetData.z, this._startOffsetData.w);
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.DELTA_OFFSET_INDEX), this._deltaOffsetData.x, this._deltaOffsetData.y, this._deltaOffsetData.z, this._deltaOffsetData.w);
+ }
+ }
+ }
+ };
+ ParticleColorState.prototype.updateColorData = function () {
+ if (this._usesCycle) {
+ if (this._cycleDuration <= 0)
+ throw (new Error("the cycle duration must be greater than zero"));
+ this._cycleData = new Vector3D(Math.PI * 2 / this._cycleDuration, this._cyclePhase * Math.PI / 180, 0, 0);
+ }
+ if (this._particleColorNode.mode == ParticlePropertiesMode.GLOBAL) {
+ if (this._usesCycle) {
+ if (this._usesMultiplier) {
+ this._startMultiplierData = new Vector3D((this._startColor.redMultiplier + this._endColor.redMultiplier) / 2, (this._startColor.greenMultiplier + this._endColor.greenMultiplier) / 2, (this._startColor.blueMultiplier + this._endColor.blueMultiplier) / 2, (this._startColor.alphaMultiplier + this._endColor.alphaMultiplier) / 2);
+ this._deltaMultiplierData = new Vector3D((this._endColor.redMultiplier - this._startColor.redMultiplier) / 2, (this._endColor.greenMultiplier - this._startColor.greenMultiplier) / 2, (this._endColor.blueMultiplier - this._startColor.blueMultiplier) / 2, (this._endColor.alphaMultiplier - this._startColor.alphaMultiplier) / 2);
+ }
+ if (this._usesOffset) {
+ this._startOffsetData = new Vector3D((this._startColor.redOffset + this._endColor.redOffset) / (255 * 2), (this._startColor.greenOffset + this._endColor.greenOffset) / (255 * 2), (this._startColor.blueOffset + this._endColor.blueOffset) / (255 * 2), (this._startColor.alphaOffset + this._endColor.alphaOffset) / (255 * 2));
+ this._deltaOffsetData = new Vector3D((this._endColor.redOffset - this._startColor.redOffset) / (255 * 2), (this._endColor.greenOffset - this._startColor.greenOffset) / (255 * 2), (this._endColor.blueOffset - this._startColor.blueOffset) / (255 * 2), (this._endColor.alphaOffset - this._startColor.alphaOffset) / (255 * 2));
+ }
+ }
+ else {
+ if (this._usesMultiplier) {
+ this._startMultiplierData = new Vector3D(this._startColor.redMultiplier, this._startColor.greenMultiplier, this._startColor.blueMultiplier, this._startColor.alphaMultiplier);
+ this._deltaMultiplierData = new Vector3D((this._endColor.redMultiplier - this._startColor.redMultiplier), (this._endColor.greenMultiplier - this._startColor.greenMultiplier), (this._endColor.blueMultiplier - this._startColor.blueMultiplier), (this._endColor.alphaMultiplier - this._startColor.alphaMultiplier));
+ }
+ if (this._usesOffset) {
+ this._startOffsetData = new Vector3D(this._startColor.redOffset / 255, this._startColor.greenOffset / 255, this._startColor.blueOffset / 255, this._startColor.alphaOffset / 255);
+ this._deltaOffsetData = new Vector3D((this._endColor.redOffset - this._startColor.redOffset) / 255, (this._endColor.greenOffset - this._startColor.greenOffset) / 255, (this._endColor.blueOffset - this._startColor.blueOffset) / 255, (this._endColor.alphaOffset - this._startColor.alphaOffset) / 255);
+ }
+ }
+ }
+ };
+ /** @private */
+ ParticleColorState.START_MULTIPLIER_INDEX = 0;
+ /** @private */
+ ParticleColorState.DELTA_MULTIPLIER_INDEX = 1;
+ /** @private */
+ ParticleColorState.START_OFFSET_INDEX = 2;
+ /** @private */
+ ParticleColorState.DELTA_OFFSET_INDEX = 3;
+ /** @private */
+ ParticleColorState.CYCLE_INDEX = 4;
+ return ParticleColorState;
+})(ParticleStateBase);
+module.exports = ParticleColorState;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/states/particlecolorstate.ts"],"names":["ParticleColorState","ParticleColorState.constructor","ParticleColorState.startColor","ParticleColorState.endColor","ParticleColorState.cycleDuration","ParticleColorState.cyclePhase","ParticleColorState.setRenderState","ParticleColorState.updateColorData"],"mappings":";;;;;;AACA,IAAO,QAAQ,WAAiB,oCAAoC,CAAC,CAAC;AAMtE,IAAO,2BAA2B,WAAY,6DAA6D,CAAC,CAAC;AAI7G,IAAO,sBAAsB,WAAa,6DAA6D,CAAC,CAAC;AAEzG,IAAO,iBAAiB,WAAc,0DAA0D,CAAC,CAAC;AAElG,AAIA;;;GADG;IACG,kBAAkB;IAASA,UAA3BA,kBAAkBA,UAA0BA;IA4FjDA,SA5FKA,kBAAkBA,CA4FXA,QAAyBA,EAAEA,iBAAmCA;QAEzEC,kBAAMA,QAAQA,EAAEA,iBAAiBA,CAACA,CAACA;QAEnCA,IAAIA,CAACA,kBAAkBA,GAAGA,iBAAiBA,CAACA;QAC5CA,IAAIA,CAACA,eAAeA,GAAGA,IAAIA,CAACA,kBAAkBA,CAACA,gBAAgBA,CAACA;QAChEA,IAAIA,CAACA,WAAWA,GAAGA,IAAIA,CAACA,kBAAkBA,CAACA,YAAYA,CAACA;QACxDA,IAAIA,CAACA,UAAUA,GAAGA,IAAIA,CAACA,kBAAkBA,CAACA,WAAWA,CAACA;QACtDA,IAAIA,CAACA,UAAUA,GAAGA,IAAIA,CAACA,kBAAkBA,CAACA,WAAWA,CAACA;QACtDA,IAAIA,CAACA,WAAWA,GAAGA,IAAIA,CAACA,kBAAkBA,CAACA,YAAYA,CAACA;QACxDA,IAAIA,CAACA,SAASA,GAAGA,IAAIA,CAACA,kBAAkBA,CAACA,UAAUA,CAACA;QACpDA,IAAIA,CAACA,cAAcA,GAAGA,IAAIA,CAACA,kBAAkBA,CAACA,eAAeA,CAACA;QAC9DA,IAAIA,CAACA,WAAWA,GAAGA,IAAIA,CAACA,kBAAkBA,CAACA,YAAYA,CAACA;QAExDA,IAAIA,CAACA,eAAeA,EAAEA,CAACA;IACxBA,CAACA;IAxEDD,sBAAWA,0CAAUA;QAHrBA;;WAEGA;aACHA;YAECE,MAAMA,CAACA,IAAIA,CAACA,WAAWA,CAACA;QACzBA,CAACA;aAEDF,UAAsBA,KAAoBA;YAEzCE,IAAIA,CAACA,WAAWA,GAAGA,KAAKA,CAACA;YAEzBA,IAAIA,CAACA,eAAeA,EAAEA,CAACA;QACxBA,CAACA;;;OAPAF;IAYDA,sBAAWA,wCAAQA;QAHnBA;;WAEGA;aACHA;YAECG,MAAMA,CAACA,IAAIA,CAACA,SAASA,CAACA;QACvBA,CAACA;aAEDH,UAAoBA,KAAoBA;YAEvCG,IAAIA,CAACA,SAASA,GAAGA,KAAKA,CAACA;YAEvBA,IAAIA,CAACA,eAAeA,EAAEA,CAACA;QACxBA,CAACA;;;OAPAH;IAYDA,sBAAWA,6CAAaA;QAHxBA;;WAEGA;aACHA;YAECI,MAAMA,CAACA,IAAIA,CAACA,cAAcA,CAACA;QAC5BA,CAACA;aAEDJ,UAAyBA,KAAYA;YAEpCI,IAAIA,CAACA,cAAcA,GAAGA,KAAKA,CAACA;YAE5BA,IAAIA,CAACA,eAAeA,EAAEA,CAACA;QACxBA,CAACA;;;OAPAJ;IAYDA,sBAAWA,0CAAUA;QAHrBA;;WAEGA;aACHA;YAECK,MAAMA,CAACA,IAAIA,CAACA,WAAWA,CAACA;QACzBA,CAACA;aAEDL,UAAsBA,KAAYA;YAEjCK,IAAIA,CAACA,WAAWA,GAAGA,KAAKA,CAACA;YAEzBA,IAAIA,CAACA,eAAeA,EAAEA,CAACA;QACxBA,CAACA;;;OAPAL;IA0BMA,2CAAcA,GAArBA,UAAsBA,KAAWA,EAAEA,UAAyBA,EAAEA,oBAAyCA,EAAEA,sBAA6CA,EAAEA,MAAaA;QAEpKM,EAAEA,CAACA,CAACA,sBAAsBA,CAACA,qBAAqBA,CAACA,CAACA,CAACA;YAClDA,IAAIA,UAAUA,GAAmBA,IAAIA,CAACA,kBAAkBA,CAACA,YAAYA,CAACA;YACtEA,EAAEA,CAACA,CAACA,IAAIA,CAACA,UAAUA,CAACA;gBACnBA,sBAAsBA,CAACA,cAAcA,CAACA,sBAAsBA,CAACA,gBAAgBA,CAACA,IAAIA,CAACA,eAAeA,EAAEA,kBAAkBA,CAACA,WAAWA,CAACA,EAAEA,IAAIA,CAACA,UAAUA,CAACA,CAACA,EAAEA,IAAIA,CAACA,UAAUA,CAACA,CAACA,EAAEA,IAAIA,CAACA,UAAUA,CAACA,CAACA,EAAEA,IAAIA,CAACA,UAAUA,CAACA,CAACA,CAACA,CAACA;YAElNA,EAAEA,CAACA,CAACA,IAAIA,CAACA,eAAeA,CAACA,CAACA,CAACA;gBAC1BA,EAAEA,CAACA,CAACA,IAAIA,CAACA,kBAAkBA,CAACA,IAAIA,IAAIA,sBAAsBA,CAACA,YAAYA,CAACA,CAACA,CAACA;oBACzEA,oBAAoBA,CAACA,oBAAoBA,CAACA,sBAAsBA,CAACA,gBAAgBA,CAACA,IAAIA,CAACA,eAAeA,EAAEA,kBAAkBA,CAACA,sBAAsBA,CAACA,EAAEA,UAAUA,EAAEA,KAAKA,EAAEA,2BAA2BA,CAACA,OAAOA,CAACA,CAACA;oBAC5MA,UAAUA,IAAIA,CAACA,CAACA;oBAChBA,oBAAoBA,CAACA,oBAAoBA,CAACA,sBAAsBA,CAACA,gBAAgBA,CAACA,IAAIA,CAACA,eAAeA,EAAEA,kBAAkBA,CAACA,sBAAsBA,CAACA,EAAEA,UAAUA,EAAEA,KAAKA,EAAEA,2BAA2BA,CAACA,OAAOA,CAACA,CAACA;oBAC5MA,UAAUA,IAAIA,CAACA,CAACA;gBACjBA,CAACA;gBAACA,IAAIA,CAACA,CAACA;oBACPA,sBAAsBA,CAACA,cAAcA,CAACA,sBAAsBA,CAACA,gBAAgBA,CAACA,IAAIA,CAACA,eAAeA,EAAEA,kBAAkBA,CAACA,sBAAsBA,CAACA,EAAEA,IAAIA,CAACA,oBAAoBA,CAACA,CAACA,EAAEA,IAAIA,CAACA,oBAAoBA,CAACA,CAACA,EAAEA,IAAIA,CAACA,oBAAoBA,CAACA,CAACA,EAAEA,IAAIA,CAACA,oBAAoBA,CAACA,CAACA,CAACA,CAACA;oBACpQA,sBAAsBA,CAACA,cAAcA,CAACA,sBAAsBA,CAACA,gBAAgBA,CAACA,IAAIA,CAACA,eAAeA,EAAEA,kBAAkBA,CAACA,sBAAsBA,CAACA,EAAEA,IAAIA,CAACA,oBAAoBA,CAACA,CAACA,EAAEA,IAAIA,CAACA,oBAAoBA,CAACA,CAACA,EAAEA,IAAIA,CAACA,oBAAoBA,CAACA,CAACA,EAAEA,IAAIA,CAACA,oBAAoBA,CAACA,CAACA,CAACA,CAACA;gBACrQA,CAACA;YACFA,CAACA;YACDA,EAAEA,CAACA,CAACA,IAAIA,CAACA,WAAWA,CAACA,CAACA,CAACA;gBACtBA,EAAEA,CAACA,CAACA,IAAIA,CAACA,kBAAkBA,CAACA,IAAIA,IAAIA,sBAAsBA,CAACA,YAAYA,CAACA,CAACA,CAACA;oBACzEA,oBAAoBA,CAACA,oBAAoBA,CAACA,sBAAsBA,CAACA,gBAAgBA,CAACA,IAAIA,CAACA,eAAeA,EAAEA,kBAAkBA,CAACA,kBAAkBA,CAACA,EAAEA,UAAUA,EAAEA,KAAKA,EAAEA,2BAA2BA,CAACA,OAAOA,CAACA,CAACA;oBACxMA,UAAUA,IAAIA,CAACA,CAACA;oBAChBA,oBAAoBA,CAACA,oBAAoBA,CAACA,sBAAsBA,CAACA,gBAAgBA,CAACA,IAAIA,CAACA,eAAeA,EAAEA,kBAAkBA,CAACA,kBAAkBA,CAACA,EAAEA,UAAUA,EAAEA,KAAKA,EAAEA,2BAA2BA,CAACA,OAAOA,CAACA,CAACA;oBACxMA,UAAUA,IAAIA,CAACA,CAACA;gBACjBA,CAACA;gBAACA,IAAIA,CAACA,CAACA;oBACPA,sBAAsBA,CAACA,cAAcA,CAACA,sBAAsBA,CAACA,gBAAgBA,CAACA,IAAIA,CAACA,eAAeA,EAAEA,kBAAkBA,CAACA,kBAAkBA,CAACA,EAAEA,IAAIA,CAACA,gBAAgBA,CAACA,CAACA,EAAEA,IAAIA,CAACA,gBAAgBA,CAACA,CAACA,EAAEA,IAAIA,CAACA,gBAAgBA,CAACA,CAACA,EAAEA,IAAIA,CAACA,gBAAgBA,CAACA,CAACA,CAACA,CAACA;oBAChPA,sBAAsBA,CAACA,cAAcA,CAACA,sBAAsBA,CAACA,gBAAgBA,CAACA,IAAIA,CAACA,eAAeA,EAAEA,kBAAkBA,CAACA,kBAAkBA,CAACA,EAAEA,IAAIA,CAACA,gBAAgBA,CAACA,CAACA,EAAEA,IAAIA,CAACA,gBAAgBA,CAACA,CAACA,EAAEA,IAAIA,CAACA,gBAAgBA,CAACA,CAACA,EAAEA,IAAIA,CAACA,gBAAgBA,CAACA,CAACA,CAACA,CAACA;gBACjPA,CAACA;YACFA,CAACA;QACFA,CAACA;IACFA,CAACA;IAEON,4CAAeA,GAAvBA;QAECO,EAAEA,CAACA,CAACA,IAAIA,CAACA,UAAUA,CAACA,CAACA,CAACA;YACrBA,EAAEA,CAACA,CAACA,IAAIA,CAACA,cAAcA,IAAIA,CAACA,CAACA;gBAC5BA,MAAKA,CAACA,IAAIA,KAAKA,CAACA,8CAA8CA,CAACA,CAACA,CAACA;YAClEA,IAAIA,CAACA,UAAUA,GAAGA,IAAIA,QAAQA,CAACA,IAAIA,CAACA,EAAEA,GAACA,CAACA,GAACA,IAAIA,CAACA,cAAcA,EAAEA,IAAIA,CAACA,WAAWA,GAACA,IAAIA,CAACA,EAAEA,GAACA,GAAGA,EAAEA,CAACA,EAAEA,CAACA,CAACA,CAACA;QACnGA,CAACA;QACDA,EAAEA,CAACA,CAACA,IAAIA,CAACA,kBAAkBA,CAACA,IAAIA,IAAIA,sBAAsBA,CAACA,MAAMA,CAACA,CAACA,CAACA;YACnEA,EAAEA,CAACA,CAACA,IAAIA,CAACA,UAAUA,CAACA,CAACA,CAACA;gBACrBA,EAAEA,CAACA,CAACA,IAAIA,CAACA,eAAeA,CAACA,CAACA,CAACA;oBAC1BA,IAAIA,CAACA,oBAAoBA,GAAGA,IAAIA,QAAQA,CAACA,CAACA,IAAIA,CAACA,WAAWA,CAACA,aAAaA,GAAGA,IAAIA,CAACA,SAASA,CAACA,aAAaA,CAACA,GAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,WAAWA,CAACA,eAAeA,GAAGA,IAAIA,CAACA,SAASA,CAACA,eAAeA,CAACA,GAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,WAAWA,CAACA,cAAcA,GAAGA,IAAIA,CAACA,SAASA,CAACA,cAAcA,CAACA,GAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,WAAWA,CAACA,eAAeA,GAAGA,IAAIA,CAACA,SAASA,CAACA,eAAeA,CAACA,GAACA,CAACA,CAACA,CAACA;oBAC/TA,IAAIA,CAACA,oBAAoBA,GAAGA,IAAIA,QAAQA,CAACA,CAACA,IAAIA,CAACA,SAASA,CAACA,aAAaA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,aAAaA,CAACA,GAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,SAASA,CAACA,eAAeA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,eAAeA,CAACA,GAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,SAASA,CAACA,cAAcA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,cAAcA,CAACA,GAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,SAASA,CAACA,eAAeA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,eAAeA,CAACA,GAACA,CAACA,CAACA,CAACA;gBAChUA,CAACA;gBAEDA,EAAEA,CAACA,CAACA,IAAIA,CAACA,WAAWA,CAACA,CAACA,CAACA;oBACtBA,IAAIA,CAACA,gBAAgBA,GAAGA,IAAIA,QAAQA,CAACA,CAACA,IAAIA,CAACA,WAAWA,CAACA,SAASA,GAAGA,IAAIA,CAACA,SAASA,CAACA,SAASA,CAACA,GAACA,CAACA,GAAGA,GAACA,CAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,WAAWA,CAACA,WAAWA,GAAGA,IAAIA,CAACA,SAASA,CAACA,WAAWA,CAACA,GAACA,CAACA,GAAGA,GAACA,CAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,WAAWA,CAACA,UAAUA,GAAGA,IAAIA,CAACA,SAASA,CAACA,UAAUA,CAACA,GAACA,CAACA,GAAGA,GAACA,CAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,WAAWA,CAACA,WAAWA,GAAGA,IAAIA,CAACA,SAASA,CAACA,WAAWA,CAACA,GAACA,CAACA,GAAGA,GAACA,CAACA,CAACA,CAACA,CAACA;oBACnTA,IAAIA,CAACA,gBAAgBA,GAAGA,IAAIA,QAAQA,CAACA,CAACA,IAAIA,CAACA,SAASA,CAACA,SAASA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,SAASA,CAACA,GAACA,CAACA,GAAGA,GAACA,CAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,SAASA,CAACA,WAAWA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,WAAWA,CAACA,GAACA,CAACA,GAAGA,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","file":"animators/states/ParticleColorState.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import ColorTransform\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/ColorTransform\");\nimport Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\nimport Camera\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Camera\");\n\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport RenderableBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/RenderableBase\");\nimport ContextGLVertexBufferFormat\t\t= require(\"awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat\");\n\nimport ParticleAnimator\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimator\");\nimport AnimationSubGeometry\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/AnimationSubGeometry\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleColorNode\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleColorNode\");\nimport ParticleStateBase\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleStateBase\");\n\n/**\n * ...\n * @author ...\n */\nclass ParticleColorState extends ParticleStateBase\n{\n\t/** @private */\n\tpublic static START_MULTIPLIER_INDEX:number /*uint*/ = 0;\n\n\t/** @private */\n\tpublic static DELTA_MULTIPLIER_INDEX:number /*uint*/ = 1;\n\n\t/** @private */\n\tpublic static START_OFFSET_INDEX:number /*uint*/ = 2;\n\n\t/** @private */\n\tpublic static DELTA_OFFSET_INDEX:number /*uint*/ = 3;\n\n\t/** @private */\n\tpublic static CYCLE_INDEX:number /*uint*/ = 4;\n\n\tprivate _particleColorNode:ParticleColorNode;\n\tprivate _usesMultiplier:boolean;\n\tprivate _usesOffset:boolean;\n\tprivate _usesCycle:boolean;\n\tprivate _usesPhase:boolean;\n\tprivate _startColor:ColorTransform;\n\tprivate _endColor:ColorTransform;\n\tprivate _cycleDuration:number;\n\tprivate _cyclePhase:number;\n\tprivate _cycleData:Vector3D;\n\tprivate _startMultiplierData:Vector3D;\n\tprivate _deltaMultiplierData:Vector3D;\n\tprivate _startOffsetData:Vector3D;\n\tprivate _deltaOffsetData:Vector3D;\n\n\t/**\n\t * Defines the start color transform of the state, when in global mode.\n\t */\n\tpublic get startColor():ColorTransform\n\t{\n\t\treturn this._startColor;\n\t}\n\n\tpublic set startColor(value:ColorTransform)\n\t{\n\t\tthis._startColor = value;\n\n\t\tthis.updateColorData();\n\t}\n\n\t/**\n\t * Defines the end color transform of the state, when in global mode.\n\t */\n\tpublic get endColor():ColorTransform\n\t{\n\t\treturn this._endColor;\n\t}\n\n\tpublic set endColor(value:ColorTransform)\n\t{\n\t\tthis._endColor = value;\n\n\t\tthis.updateColorData();\n\t}\n\n\t/**\n\t * Defines the duration of the animation in seconds, used as a period independent of particle duration when in global mode. Defaults to 1.\n\t */\n\tpublic get cycleDuration():number\n\t{\n\t\treturn this._cycleDuration;\n\t}\n\n\tpublic set cycleDuration(value:number)\n\t{\n\t\tthis._cycleDuration = value;\n\n\t\tthis.updateColorData();\n\t}\n\n\t/**\n\t * Defines the phase of the cycle in degrees, used as the starting offset of the cycle when in global mode. Defaults to 0.\n\t */\n\tpublic get cyclePhase():number\n\t{\n\t\treturn this._cyclePhase;\n\t}\n\n\tpublic set cyclePhase(value:number)\n\t{\n\t\tthis._cyclePhase = value;\n\n\t\tthis.updateColorData();\n\t}\n\n\tconstructor(animator:ParticleAnimator, particleColorNode:ParticleColorNode)\n\t{\n\t\tsuper(animator, particleColorNode);\n\n\t\tthis._particleColorNode = particleColorNode;\n\t\tthis._usesMultiplier = this._particleColorNode._iUsesMultiplier;\n\t\tthis._usesOffset = this._particleColorNode._iUsesOffset;\n\t\tthis._usesCycle = this._particleColorNode._iUsesCycle;\n\t\tthis._usesPhase = this._particleColorNode._iUsesPhase;\n\t\tthis._startColor = this._particleColorNode._iStartColor;\n\t\tthis._endColor = this._particleColorNode._iEndColor;\n\t\tthis._cycleDuration = this._particleColorNode._iCycleDuration;\n\t\tthis._cyclePhase = this._particleColorNode._iCyclePhase;\n\n\t\tthis.updateColorData();\n\t}\n\n\tpublic setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)\n\t{\n\t\tif (animationRegisterCache.needFragmentAnimation) {\n\t\t\tvar dataOffset:number /*uint*/ = this._particleColorNode._iDataOffset;\n\t\t\tif (this._usesCycle)\n\t\t\t\tanimationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.CYCLE_INDEX), this._cycleData.x, this._cycleData.y, this._cycleData.z, this._cycleData.w);\n\n\t\t\tif (this._usesMultiplier) {\n\t\t\t\tif (this._particleColorNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {\n\t\t\t\t\tanimationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.START_MULTIPLIER_INDEX), dataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);\n\t\t\t\t\tdataOffset += 4;\n\t\t\t\t\tanimationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.DELTA_MULTIPLIER_INDEX), dataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);\n\t\t\t\t\tdataOffset += 4;\n\t\t\t\t} else {\n\t\t\t\t\tanimationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.START_MULTIPLIER_INDEX), this._startMultiplierData.x, this._startMultiplierData.y, this._startMultiplierData.z, this._startMultiplierData.w);\n\t\t\t\t\tanimationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.DELTA_MULTIPLIER_INDEX), this._deltaMultiplierData.x, this._deltaMultiplierData.y, this._deltaMultiplierData.z, this._deltaMultiplierData.w);\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (this._usesOffset) {\n\t\t\t\tif (this._particleColorNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {\n\t\t\t\t\tanimationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.START_OFFSET_INDEX), dataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);\n\t\t\t\t\tdataOffset += 4;\n\t\t\t\t\tanimationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.DELTA_OFFSET_INDEX), dataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);\n\t\t\t\t\tdataOffset += 4;\n\t\t\t\t} else {\n\t\t\t\t\tanimationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.START_OFFSET_INDEX), this._startOffsetData.x, this._startOffsetData.y, this._startOffsetData.z, this._startOffsetData.w);\n\t\t\t\t\tanimationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.DELTA_OFFSET_INDEX), this._deltaOffsetData.x, this._deltaOffsetData.y, this._deltaOffsetData.z, this._deltaOffsetData.w);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate updateColorData()\n\t{\n\t\tif (this._usesCycle) {\n\t\t\tif (this._cycleDuration <= 0)\n\t\t\t\tthrow(new Error(\"the cycle duration must be greater than zero\"));\n\t\t\tthis._cycleData = new Vector3D(Math.PI*2/this._cycleDuration, this._cyclePhase*Math.PI/180, 0, 0);\n\t\t}\n\t\tif (this._particleColorNode.mode == ParticlePropertiesMode.GLOBAL) {\n\t\t\tif (this._usesCycle) {\n\t\t\t\tif (this._usesMultiplier) {\n\t\t\t\t\tthis._startMultiplierData = new Vector3D((this._startColor.redMultiplier + this._endColor.redMultiplier)/2, (this._startColor.greenMultiplier + this._endColor.greenMultiplier)/2, (this._startColor.blueMultiplier + this._endColor.blueMultiplier)/2, (this._startColor.alphaMultiplier + this._endColor.alphaMultiplier)/2);\n\t\t\t\t\tthis._deltaMultiplierData = new Vector3D((this._endColor.redMultiplier - this._startColor.redMultiplier)/2, (this._endColor.greenMultiplier - this._startColor.greenMultiplier)/2, (this._endColor.blueMultiplier - this._startColor.blueMultiplier)/2, (this._endColor.alphaMultiplier - this._startColor.alphaMultiplier)/2);\n\t\t\t\t}\n\n\t\t\t\tif (this._usesOffset) {\n\t\t\t\t\tthis._startOffsetData = new Vector3D((this._startColor.redOffset + this._endColor.redOffset)/(255*2), (this._startColor.greenOffset + this._endColor.greenOffset)/(255*2), (this._startColor.blueOffset + this._endColor.blueOffset)/(255*2), (this._startColor.alphaOffset + this._endColor.alphaOffset)/(255*2));\n\t\t\t\t\tthis._deltaOffsetData = new Vector3D((this._endColor.redOffset - this._startColor.redOffset)/(255*2), (this._endColor.greenOffset - this._startColor.greenOffset)/(255*2), (this._endColor.blueOffset - this._startColor.blueOffset)/(255*2), (this._endColor.alphaOffset - this._startColor.alphaOffset)/(255*2));\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif (this._usesMultiplier) {\n\t\t\t\t\tthis._startMultiplierData = new Vector3D(this._startColor.redMultiplier, this._startColor.greenMultiplier, this._startColor.blueMultiplier, this._startColor.alphaMultiplier);\n\t\t\t\t\tthis._deltaMultiplierData = new Vector3D((this._endColor.redMultiplier - this._startColor.redMultiplier), (this._endColor.greenMultiplier - this._startColor.greenMultiplier), (this._endColor.blueMultiplier - this._startColor.blueMultiplier), (this._endColor.alphaMultiplier - this._startColor.alphaMultiplier));\n\t\t\t\t}\n\n\t\t\t\tif (this._usesOffset) {\n\t\t\t\t\tthis._startOffsetData = new Vector3D(this._startColor.redOffset/255, this._startColor.greenOffset/255, this._startColor.blueOffset/255, this._startColor.alphaOffset/255);\n\t\t\t\t\tthis._deltaOffsetData = new Vector3D((this._endColor.redOffset - this._startColor.redOffset)/255, (this._endColor.greenOffset - this._startColor.greenOffset)/255, (this._endColor.blueOffset - this._startColor.blueOffset )/255, (this._endColor.alphaOffset - this._startColor.alphaOffset)/255);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n}\n\nexport = ParticleColorState;"]}
\ No newline at end of file
diff --git a/lib/animators/states/ParticleColorState.ts b/lib/animators/states/ParticleColorState.ts
new file mode 100644
index 000000000..6e9fc2110
--- /dev/null
+++ b/lib/animators/states/ParticleColorState.ts
@@ -0,0 +1,194 @@
+import ColorTransform = require("awayjs-core/lib/core/geom/ColorTransform");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+
+import ParticleAnimator = require("awayjs-renderergl/lib/animators/ParticleAnimator");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleColorNode = require("awayjs-renderergl/lib/animators/nodes/ParticleColorNode");
+import ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+
+/**
+ * ...
+ * @author ...
+ */
+class ParticleColorState extends ParticleStateBase
+{
+ /** @private */
+ public static START_MULTIPLIER_INDEX:number /*uint*/ = 0;
+
+ /** @private */
+ public static DELTA_MULTIPLIER_INDEX:number /*uint*/ = 1;
+
+ /** @private */
+ public static START_OFFSET_INDEX:number /*uint*/ = 2;
+
+ /** @private */
+ public static DELTA_OFFSET_INDEX:number /*uint*/ = 3;
+
+ /** @private */
+ public static CYCLE_INDEX:number /*uint*/ = 4;
+
+ private _particleColorNode:ParticleColorNode;
+ private _usesMultiplier:boolean;
+ private _usesOffset:boolean;
+ private _usesCycle:boolean;
+ private _usesPhase:boolean;
+ private _startColor:ColorTransform;
+ private _endColor:ColorTransform;
+ private _cycleDuration:number;
+ private _cyclePhase:number;
+ private _cycleData:Vector3D;
+ private _startMultiplierData:Vector3D;
+ private _deltaMultiplierData:Vector3D;
+ private _startOffsetData:Vector3D;
+ private _deltaOffsetData:Vector3D;
+
+ /**
+ * Defines the start color transform of the state, when in global mode.
+ */
+ public get startColor():ColorTransform
+ {
+ return this._startColor;
+ }
+
+ public set startColor(value:ColorTransform)
+ {
+ this._startColor = value;
+
+ this.updateColorData();
+ }
+
+ /**
+ * Defines the end color transform of the state, when in global mode.
+ */
+ public get endColor():ColorTransform
+ {
+ return this._endColor;
+ }
+
+ public set endColor(value:ColorTransform)
+ {
+ this._endColor = value;
+
+ this.updateColorData();
+ }
+
+ /**
+ * Defines the duration of the animation in seconds, used as a period independent of particle duration when in global mode. Defaults to 1.
+ */
+ public get cycleDuration():number
+ {
+ return this._cycleDuration;
+ }
+
+ public set cycleDuration(value:number)
+ {
+ this._cycleDuration = value;
+
+ this.updateColorData();
+ }
+
+ /**
+ * Defines the phase of the cycle in degrees, used as the starting offset of the cycle when in global mode. Defaults to 0.
+ */
+ public get cyclePhase():number
+ {
+ return this._cyclePhase;
+ }
+
+ public set cyclePhase(value:number)
+ {
+ this._cyclePhase = value;
+
+ this.updateColorData();
+ }
+
+ constructor(animator:ParticleAnimator, particleColorNode:ParticleColorNode)
+ {
+ super(animator, particleColorNode);
+
+ this._particleColorNode = particleColorNode;
+ this._usesMultiplier = this._particleColorNode._iUsesMultiplier;
+ this._usesOffset = this._particleColorNode._iUsesOffset;
+ this._usesCycle = this._particleColorNode._iUsesCycle;
+ this._usesPhase = this._particleColorNode._iUsesPhase;
+ this._startColor = this._particleColorNode._iStartColor;
+ this._endColor = this._particleColorNode._iEndColor;
+ this._cycleDuration = this._particleColorNode._iCycleDuration;
+ this._cyclePhase = this._particleColorNode._iCyclePhase;
+
+ this.updateColorData();
+ }
+
+ public setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)
+ {
+ if (animationRegisterCache.needFragmentAnimation) {
+ var dataOffset:number /*uint*/ = this._particleColorNode._iDataOffset;
+ if (this._usesCycle)
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.CYCLE_INDEX), this._cycleData.x, this._cycleData.y, this._cycleData.z, this._cycleData.w);
+
+ if (this._usesMultiplier) {
+ if (this._particleColorNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.START_MULTIPLIER_INDEX), dataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ dataOffset += 4;
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.DELTA_MULTIPLIER_INDEX), dataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ dataOffset += 4;
+ } else {
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.START_MULTIPLIER_INDEX), this._startMultiplierData.x, this._startMultiplierData.y, this._startMultiplierData.z, this._startMultiplierData.w);
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.DELTA_MULTIPLIER_INDEX), this._deltaMultiplierData.x, this._deltaMultiplierData.y, this._deltaMultiplierData.z, this._deltaMultiplierData.w);
+ }
+ }
+ if (this._usesOffset) {
+ if (this._particleColorNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.START_OFFSET_INDEX), dataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ dataOffset += 4;
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.DELTA_OFFSET_INDEX), dataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ dataOffset += 4;
+ } else {
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.START_OFFSET_INDEX), this._startOffsetData.x, this._startOffsetData.y, this._startOffsetData.z, this._startOffsetData.w);
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleColorState.DELTA_OFFSET_INDEX), this._deltaOffsetData.x, this._deltaOffsetData.y, this._deltaOffsetData.z, this._deltaOffsetData.w);
+ }
+ }
+ }
+ }
+
+ private updateColorData()
+ {
+ if (this._usesCycle) {
+ if (this._cycleDuration <= 0)
+ throw(new Error("the cycle duration must be greater than zero"));
+ this._cycleData = new Vector3D(Math.PI*2/this._cycleDuration, this._cyclePhase*Math.PI/180, 0, 0);
+ }
+ if (this._particleColorNode.mode == ParticlePropertiesMode.GLOBAL) {
+ if (this._usesCycle) {
+ if (this._usesMultiplier) {
+ this._startMultiplierData = new Vector3D((this._startColor.redMultiplier + this._endColor.redMultiplier)/2, (this._startColor.greenMultiplier + this._endColor.greenMultiplier)/2, (this._startColor.blueMultiplier + this._endColor.blueMultiplier)/2, (this._startColor.alphaMultiplier + this._endColor.alphaMultiplier)/2);
+ this._deltaMultiplierData = new Vector3D((this._endColor.redMultiplier - this._startColor.redMultiplier)/2, (this._endColor.greenMultiplier - this._startColor.greenMultiplier)/2, (this._endColor.blueMultiplier - this._startColor.blueMultiplier)/2, (this._endColor.alphaMultiplier - this._startColor.alphaMultiplier)/2);
+ }
+
+ if (this._usesOffset) {
+ this._startOffsetData = new Vector3D((this._startColor.redOffset + this._endColor.redOffset)/(255*2), (this._startColor.greenOffset + this._endColor.greenOffset)/(255*2), (this._startColor.blueOffset + this._endColor.blueOffset)/(255*2), (this._startColor.alphaOffset + this._endColor.alphaOffset)/(255*2));
+ this._deltaOffsetData = new Vector3D((this._endColor.redOffset - this._startColor.redOffset)/(255*2), (this._endColor.greenOffset - this._startColor.greenOffset)/(255*2), (this._endColor.blueOffset - this._startColor.blueOffset)/(255*2), (this._endColor.alphaOffset - this._startColor.alphaOffset)/(255*2));
+ }
+ } else {
+ if (this._usesMultiplier) {
+ this._startMultiplierData = new Vector3D(this._startColor.redMultiplier, this._startColor.greenMultiplier, this._startColor.blueMultiplier, this._startColor.alphaMultiplier);
+ this._deltaMultiplierData = new Vector3D((this._endColor.redMultiplier - this._startColor.redMultiplier), (this._endColor.greenMultiplier - this._startColor.greenMultiplier), (this._endColor.blueMultiplier - this._startColor.blueMultiplier), (this._endColor.alphaMultiplier - this._startColor.alphaMultiplier));
+ }
+
+ if (this._usesOffset) {
+ this._startOffsetData = new Vector3D(this._startColor.redOffset/255, this._startColor.greenOffset/255, this._startColor.blueOffset/255, this._startColor.alphaOffset/255);
+ this._deltaOffsetData = new Vector3D((this._endColor.redOffset - this._startColor.redOffset)/255, (this._endColor.greenOffset - this._startColor.greenOffset)/255, (this._endColor.blueOffset - this._startColor.blueOffset )/255, (this._endColor.alphaOffset - this._startColor.alphaOffset)/255);
+ }
+ }
+ }
+ }
+}
+
+export = ParticleColorState;
\ No newline at end of file
diff --git a/lib/animators/states/ParticleFollowState.js b/lib/animators/states/ParticleFollowState.js
new file mode 100755
index 000000000..239e227f8
--- /dev/null
+++ b/lib/animators/states/ParticleFollowState.js
@@ -0,0 +1,219 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var MathConsts = require("awayjs-core/lib/core/geom/MathConsts");
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+var ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+/**
+ * ...
+ */
+var ParticleFollowState = (function (_super) {
+ __extends(ParticleFollowState, _super);
+ function ParticleFollowState(animator, particleFollowNode) {
+ _super.call(this, animator, particleFollowNode, true);
+ this._targetPos = new Vector3D();
+ this._targetEuler = new Vector3D();
+ //temporary vector3D for calculation
+ this._temp = new Vector3D();
+ this._particleFollowNode = particleFollowNode;
+ this._smooth = particleFollowNode._iSmooth;
+ }
+ Object.defineProperty(ParticleFollowState.prototype, "followTarget", {
+ get: function () {
+ return this._followTarget;
+ },
+ set: function (value) {
+ this._followTarget = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleFollowState.prototype, "smooth", {
+ get: function () {
+ return this._smooth;
+ },
+ set: function (value) {
+ this._smooth = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ ParticleFollowState.prototype.setRenderState = function (stage, renderable, animationSubGeometry, animationRegisterCache, camera) {
+ if (this._followTarget) {
+ if (this._particleFollowNode._iUsesPosition) {
+ this._targetPos.x = this._followTarget.transform.position.x / renderable.sourceEntity.scaleX;
+ this._targetPos.y = this._followTarget.transform.position.y / renderable.sourceEntity.scaleY;
+ this._targetPos.z = this._followTarget.transform.position.z / renderable.sourceEntity.scaleZ;
+ }
+ if (this._particleFollowNode._iUsesRotation) {
+ this._targetEuler.x = this._followTarget.rotationX;
+ this._targetEuler.y = this._followTarget.rotationY;
+ this._targetEuler.z = this._followTarget.rotationZ;
+ this._targetEuler.scaleBy(MathConsts.DEGREES_TO_RADIANS);
+ }
+ }
+ //initialization
+ if (!this._prePos)
+ this._prePos = this._targetPos.clone();
+ if (!this._preEuler)
+ this._preEuler = this._targetEuler.clone();
+ var currentTime = this._pTime / 1000;
+ var previousTime = animationSubGeometry.previousTime;
+ var deltaTime = currentTime - previousTime;
+ var needProcess = previousTime != currentTime;
+ if (this._particleFollowNode._iUsesPosition && this._particleFollowNode._iUsesRotation) {
+ if (needProcess)
+ this.processPositionAndRotation(currentTime, deltaTime, animationSubGeometry);
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleFollowState.FOLLOW_POSITION_INDEX), this._particleFollowNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleFollowState.FOLLOW_ROTATION_INDEX), this._particleFollowNode._iDataOffset + 3, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ }
+ else if (this._particleFollowNode._iUsesPosition) {
+ if (needProcess)
+ this.processPosition(currentTime, deltaTime, animationSubGeometry);
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleFollowState.FOLLOW_POSITION_INDEX), this._particleFollowNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ }
+ else if (this._particleFollowNode._iUsesRotation) {
+ if (needProcess)
+ this.precessRotation(currentTime, deltaTime, animationSubGeometry);
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleFollowState.FOLLOW_ROTATION_INDEX), this._particleFollowNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ }
+ this._prePos.copyFrom(this._targetPos);
+ this._targetEuler.copyFrom(this._targetEuler);
+ animationSubGeometry.previousTime = currentTime;
+ };
+ ParticleFollowState.prototype.processPosition = function (currentTime, deltaTime, animationSubGeometry) {
+ var data = animationSubGeometry.animationParticles;
+ var vertexData = animationSubGeometry.vertexData;
+ var changed = false;
+ var len = data.length;
+ var interpolatedPos;
+ var posVelocity;
+ if (this._smooth) {
+ posVelocity = this._prePos.subtract(this._targetPos);
+ posVelocity.scaleBy(1 / deltaTime);
+ }
+ else
+ interpolatedPos = this._targetPos;
+ for (var i = 0; i < len; i++) {
+ var k = (currentTime - data[i].startTime) / data[i].totalTime;
+ var t = (k - Math.floor(k)) * data[i].totalTime;
+ if (t - deltaTime <= 0) {
+ var inc = data[i].startVertexIndex * animationSubGeometry.totalLenOfOneVertex + this._particleFollowNode._iDataOffset;
+ if (this._smooth) {
+ this._temp.copyFrom(posVelocity);
+ this._temp.scaleBy(t);
+ interpolatedPos = this._targetPos.add(this._temp);
+ }
+ if (vertexData[inc] != interpolatedPos.x || vertexData[inc + 1] != interpolatedPos.y || vertexData[inc + 2] != interpolatedPos.z) {
+ changed = true;
+ for (var j = 0; j < data[i].numVertices; j++) {
+ vertexData[inc++] = interpolatedPos.x;
+ vertexData[inc++] = interpolatedPos.y;
+ vertexData[inc++] = interpolatedPos.z;
+ }
+ }
+ }
+ }
+ if (changed)
+ animationSubGeometry.invalidateBuffer();
+ };
+ ParticleFollowState.prototype.precessRotation = function (currentTime, deltaTime, animationSubGeometry) {
+ var data = animationSubGeometry.animationParticles;
+ var vertexData = animationSubGeometry.vertexData;
+ var changed = false;
+ var len = data.length;
+ var interpolatedRotation;
+ var rotationVelocity;
+ if (this._smooth) {
+ rotationVelocity = this._preEuler.subtract(this._targetEuler);
+ rotationVelocity.scaleBy(1 / deltaTime);
+ }
+ else
+ interpolatedRotation = this._targetEuler;
+ for (var i = 0; i < len; i++) {
+ var k = (currentTime - data[i].startTime) / data[i].totalTime;
+ var t = (k - Math.floor(k)) * data[i].totalTime;
+ if (t - deltaTime <= 0) {
+ var inc = data[i].startVertexIndex * animationSubGeometry.totalLenOfOneVertex + this._particleFollowNode._iDataOffset;
+ if (this._smooth) {
+ this._temp.copyFrom(rotationVelocity);
+ this._temp.scaleBy(t);
+ interpolatedRotation = this._targetEuler.add(this._temp);
+ }
+ if (vertexData[inc] != interpolatedRotation.x || vertexData[inc + 1] != interpolatedRotation.y || vertexData[inc + 2] != interpolatedRotation.z) {
+ changed = true;
+ for (var j = 0; j < data[i].numVertices; j++) {
+ vertexData[inc++] = interpolatedRotation.x;
+ vertexData[inc++] = interpolatedRotation.y;
+ vertexData[inc++] = interpolatedRotation.z;
+ }
+ }
+ }
+ }
+ if (changed)
+ animationSubGeometry.invalidateBuffer();
+ };
+ ParticleFollowState.prototype.processPositionAndRotation = function (currentTime, deltaTime, animationSubGeometry) {
+ var data = animationSubGeometry.animationParticles;
+ var vertexData = animationSubGeometry.vertexData;
+ var changed = false;
+ var len = data.length;
+ var interpolatedPos;
+ var interpolatedRotation;
+ var posVelocity;
+ var rotationVelocity;
+ if (this._smooth) {
+ posVelocity = this._prePos.subtract(this._targetPos);
+ posVelocity.scaleBy(1 / deltaTime);
+ rotationVelocity = this._preEuler.subtract(this._targetEuler);
+ rotationVelocity.scaleBy(1 / deltaTime);
+ }
+ else {
+ interpolatedPos = this._targetPos;
+ interpolatedRotation = this._targetEuler;
+ }
+ for (var i = 0; i < len; i++) {
+ var k = (currentTime - data[i].startTime) / data[i].totalTime;
+ var t = (k - Math.floor(k)) * data[i].totalTime;
+ if (t - deltaTime <= 0) {
+ var inc = data[i].startVertexIndex * animationSubGeometry.totalLenOfOneVertex + this._particleFollowNode._iDataOffset;
+ if (this._smooth) {
+ this._temp.copyFrom(posVelocity);
+ this._temp.scaleBy(t);
+ interpolatedPos = this._targetPos.add(this._temp);
+ this._temp.copyFrom(rotationVelocity);
+ this._temp.scaleBy(t);
+ interpolatedRotation = this._targetEuler.add(this._temp);
+ }
+ if (vertexData[inc] != interpolatedPos.x || vertexData[inc + 1] != interpolatedPos.y || vertexData[inc + 2] != interpolatedPos.z || vertexData[inc + 3] != interpolatedRotation.x || vertexData[inc + 4] != interpolatedRotation.y || vertexData[inc + 5] != interpolatedRotation.z) {
+ changed = true;
+ for (var j = 0; j < data[i].numVertices; j++) {
+ vertexData[inc++] = interpolatedPos.x;
+ vertexData[inc++] = interpolatedPos.y;
+ vertexData[inc++] = interpolatedPos.z;
+ vertexData[inc++] = interpolatedRotation.x;
+ vertexData[inc++] = interpolatedRotation.y;
+ vertexData[inc++] = interpolatedRotation.z;
+ }
+ }
+ }
+ }
+ if (changed)
+ animationSubGeometry.invalidateBuffer();
+ };
+ /** @private */
+ ParticleFollowState.FOLLOW_POSITION_INDEX = 0;
+ /** @private */
+ ParticleFollowState.FOLLOW_ROTATION_INDEX = 1;
+ return ParticleFollowState;
+})(ParticleStateBase);
+module.exports = ParticleFollowState;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/states/particlefollowstate.ts"],"names":["ParticleFollowState","ParticleFollowState.constructor","ParticleFollowState.followTarget","ParticleFollowState.smooth","ParticleFollowState.setRenderState","ParticleFollowState.processPosition","ParticleFollowState.precessRotation","ParticleFollowState.processPositionAndRotation"],"mappings":";;;;;;AACA,IAAO,UAAU,WAAgB,sCAAsC,CAAC,CAAC;AACzE,IAAO,QAAQ,WAAiB,oCAAoC,CAAC,CAAC;AAMtE,IAAO,2BAA2B,WAAY,6DAA6D,CAAC,CAAC;AAM7G,IAAO,iBAAiB,WAAc,0DAA0D,CAAC,CAAC;AAElG,AAGA;;GADG;IACG,mBAAmB;IAASA,UAA5BA,mBAAmBA,UAA0BA;IAoBlDA,SApBKA,mBAAmBA,CAoBZA,QAAyBA,EAAEA,kBAAqCA;QAE3EC,kBAAMA,QAAQA,EAAEA,kBAAkBA,EAAEA,IAAIA,CAACA,CAACA;QAXnCA,eAAUA,GAAYA,IAAIA,QAAQA,EAAEA,CAACA;QACrCA,iBAAYA,GAAYA,IAAIA,QAAQA,EAAEA,CAACA;QAK/CA,oCAAoCA;QAC5BA,UAAKA,GAAYA,IAAIA,QAAQA,EAAEA,CAACA;QAMvCA,IAAIA,CAACA,mBAAmBA,GAAGA,kBAAkBA,CAACA;QAC9CA,IAAIA,CAACA,OAAOA,GAAGA,kBAAkBA,CAACA,QAAQA,CAACA;IAC5CA,CAACA;IAEDD,sBAAWA,6CAAYA;aAAvBA;YAECE,MAAMA,CAACA,IAAIA,CAACA,aAAaA,CAACA;QAC3BA,CAACA;aAEDF,UAAwBA,KAAmBA;YAE1CE,IAAIA,CAACA,aAAaA,GAAGA,KAAKA,CAACA;QAC5BA,CAACA;;;OALAF;IAODA,sBAAWA,uCAAMA;aAAjBA;YAECG,MAAMA,CAACA,IAAIA,CAACA,OAAOA,CAACA;QACrBA,CAACA;aAEDH,UAAkBA,KAAaA;YAE9BG,IAAIA,CAACA,OAAOA,GAAGA,KAAKA,CAACA;QACtBA,CAACA;;;OALAH;IAODA;;OAEGA;IACIA,4CAAcA,GAArBA,UAAsBA,KAAWA,EAAEA,UAAyBA,EAAEA,oBAAyCA,EAAEA,sBAA6CA,EAAEA,MAAaA;QAEpKI,EAAEA,CAACA,CAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA;YACxBA,EAAEA,CAACA,CAACA,IAAIA,CAACA,mBAAmBA,CAACA,cAAcA,CAACA,CAACA,CAACA;gBAC7CA,IAAIA,CAACA,UAAUA,CAACA,CAACA,GAAGA,IAAIA,CAACA,aAAaA,CAACA,SAASA,CAACA,QAAQA,CAACA,CAACA,GAACA,UAAUA,CAACA,YAAYA,CAACA,MAAMA,CAACA;gBAC3FA,IAAIA,CAACA,UAAUA,CAACA,CAACA,GAAGA,IAAIA,CAACA,aAAaA,CAACA,SAASA,CAACA,QAAQA,CAACA,CAACA,GAACA,UAAUA,CAACA,YAAYA,CAACA,MAAMA,CAACA;gBAC3FA,IAAIA,CAACA,UAAUA,CAACA,CAACA,GAAGA,IAAIA,CAACA,aAAaA,CAACA,SAASA,CAACA,QAAQA,CAACA,CAACA,GAACA,UAAUA,CAACA,YAAYA,CAACA,MAAMA,CAACA;YAC5FA,CAACA;YACDA,EAAEA,CAACA,CAACA,IAAIA,CAACA,mBAAmBA,CAACA,cAAcA,CAACA,CAACA,CAACA;gBAC7CA,IAAIA,CAACA,YAAYA,CAACA,CAACA,GAAGA,IAAIA,CAACA,aAAaA,CAACA,SAASA,CAACA;gBACnDA,IAAIA,CAACA,YAAYA,CAACA,CAACA,GAAGA,IAAIA,CAACA,aAAaA,CAACA,SAASA,CAACA;gBACnDA,IAAIA,CAACA,YAAYA,CAACA,CAACA,GAAGA,IAAIA,CAACA,aAAaA,CAACA,SAASA,CAACA;gBACnDA,IAAIA,CAACA,YAAYA,CAACA,OAAOA,CAACA,UAAUA,CAACA,kBAAkBA,CAACA,CAACA;YAC1DA,CAACA;QACFA,CAACA;QACDA,AACAA,gBADgBA;QAChBA,EAAEA,CAACA,CAACA,CAACA,IAAIA,CAACA,OAAOA,CAACA;YACjBA,IAAIA,CAACA,OAAOA,GAAGA,IAAIA,CAACA,UAAUA,CAACA,KAAKA,EAAEA,CAACA;QACxCA,EAAEA,CAACA,CAACA,CAACA,IAAIA,CAACA,SAASA,CAACA;YACnBA,IAAIA,CAACA,SAASA,GAAGA,IAAIA,CAACA,YAAYA,CAACA,KAAKA,EAAEA,CAACA;QAE5CA,IAAIA,WAAWA,GAAUA,IAAIA,CAACA,MAAMA,GAACA,IAAIA,CAACA;QAC1CA,IAAIA,YAAYA,GAAUA,oBAAoBA,CAACA,YAAYA,CAACA;QAC5DA,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CA,GAAmBA,CAACA,EAAEA,CAACA,GAAGA,GAAGA,EAAEA,CAACA,EAAEA,EAAEA,CAACA;YAC9CA,IAAIA,CAACA,GAAUA,CAACA,WAAWA,GAAGA,IAAIA,CAACA,CAACA,CAACA,CAACA,SAASA,CAACA,GAACA,IAAIA,CAACA,CAACA,CAACA,CAACA,SAASA,CAACA;YACnEA,IAAIA,CAACA,GAAUA,CAACA,CAACA,GAAGA,IAAIA,CAACA,KAAKA,CAACA,CAACA,CAACA,CAACA,GAACA,IAAIA,CAACA,CAACA,CAACA,CAACA,SAASA,CAACA;YACrDA,EAAEA,CAACA,CAACA,CAACA,GAAGA,SAASA,IAAIA,CAACA,CAACA,CAACA,CAACA;gBACxBA,IAAIA,GAAGA,GAAkBA,IAAIA,CAACA,CAACA,CAACA,CAACA,gBAAgBA,GAACA,oBAAoBA,CAACA,mBAAmBA,GAAGA,IAAIA,CAACA,mBAAmBA,CAACA,YAAYA,CAACA;gBAEnIA,EAAEA,CAACA,CAACA,IAAIA,CAACA,OAAOA,CAACA,CAACA,CAACA;oBAClBA,IAAIA,CAACA,KAAKA,CAACA,QAAQA,CAACA,WAAWA,CAACA,CAACA;oBACjCA,IAAIA,CAACA,KAAKA,CAACA,OAAOA,CAACA,CAACA,CAACA,CAACA;oBACtBA,eAAeA,GAAGA,IAAIA,CAACA,UAAUA,CAACA,GAAGA,CAACA,IAAIA,CAACA,KAAKA,CAACA,CAACA;gBACnDA,CAACA;gBAEDA,EAAEA,CAACA,CAACA,UAAUA,CAACA,GAAGA,CAACA,IAAIA,eAAeA,CAACA,CAACA,IAAIA,UAAUA,CAACA,GAAGA,GAAGA,CAACA,CAACA,IAAIA,eAAeA,CAACA,CAACA,IAAIA,UAAUA,CAACA,GAAGA,GAAGA,CAACA,CAACA,IAAIA,eAAeA,CAACA,CAACA,CAACA,CAACA,CAACA;oBAClIA,OAAOA,GAAGA,IAAIA,CAACA;oBACfA,GAAGA,CAACA,CAACA,GAAGA,CAACA,CAACA,GAAmBA,CAACA,EAAEA,CAACA,GAAGA,IAAIA,CAACA,CAACA,CAACA,CAACA,WAAWA,EAA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AACA,CAACA,CAACA,CAACA,SAASA,CAACA,GAACA,IAAIA,CAACA,CAACA,CAACA,CAACA,SAASA,CAACA;YACnEA,IAAIA,CAACA,GAAUA,CAACA,CAACA,GAAGA,IAAIA,CAACA,KAAKA,CAACA,CAACA,CAACA,CAACA,GAACA,IAAIA,CAACA,CAACA,CAACA,CAACA,SAASA,CAACA;YACrDA,EAAEA,CAACA,CAACA,CAACA,GAAGA,SAASA,IAAIA,CAACA,CAACA,CAACA,CAACA;gBACxBA,IAAIA,GAAGA,GAAkBA,IAAIA,CAACA,CAACA,CAACA,CAACA,gBAAgBA,GAACA,oBAAoBA,CAACA,mBAAmBA,GAAGA,IAAIA,CAACA,mBAAmBA,CAACA,YAAYA,CAACA;gBACnIA,EAAEA,CAACA,CAACA,IAAIA,CAACA,OAAOA,CAACA,CAACA,CAACA;oBAClBA,IAAIA,CAACA,KAAKA,CAACA,QAAQA,CAACA,WAAWA,CAACA,CAACA;oBACjCA,IAAIA,CAACA,KAAKA,CAACA,OAAOA,CAACA,CAACA,CAACA,CAACA;oBACtBA,eAAeA,GAAGA,IAAIA,CAACA,UAAUA,CAACA,GAAGA,CAACA,IAAIA,CAACA,KAAKA,CAACA,CAACA;oBAElDA,IAAIA,CAACA,KAAKA,CAACA,QAAQA,CAACA,gBAAgBA,CAACA,CAACA;oBACtCA,IAAIA,CAACA,KAAKA,CAACA,OAAOA,CAACA,CAACA,CAACA,CAACA;oBACtBA,oBAAoBA,GAAGA,IAAIA,CAACA,YAAYA,CAACA,GAAGA,CAACA,IAAIA,CAACA,KAAKA,CAACA,CAACA;gBAC1DA,CAACA;gBAEDA,EAAEA,CAACA,CAACA,UAAUA,CAACA,GAAGA,CAACA,IAAIA,eAAeA,CAACA,CAACA,IAAIA,UAAUA,CAACA,GAAGA,GAAGA,CAACA,CAACA,IAAIA,eAAeA,CAACA,CAACA,IAAIA,UAAUA,CAACA,GAAGA,GAAGA,CAACA,CAACA,IAAIA,eAAeA,CAACA,CAACA,IAAIA,UAAUA,CAACA,GAAGA,GAAGA,CAACA,CAACA,IAAIA,oBAAoBA,CAACA,CAACA,IAAIA,UAAUA,CAACA,GAAGA,GAAGA,CAACA,CAACA,IAAIA,oBAAoBA,CAACA,CAACA,IAAIA,UAAUA,CAACA,GAAGA,GAAGA,CAACA,CAACA,IAAIA,oBAAoBA,CAACA,CAACA,CAACA,CAACA,CAACA;oBACrRA,OAAOA,GAAGA,IAAIA,CAACA;oBACfA,GAAGA,CAACA,CAACA,GAAGA,CAACA,CAACA,GAAmBA,CAACA,EAAEA,CAACA,GAAGA,IAAIA,CAACA,CAACA,CAACA,CAACA,WAAWA,EAAEA,CAACA,EAAEA,EAAEA,CAACA;wBAC9DA,UAAUA,CAACA,GAAGA,EAAEA,CAACA,GAAGA,eAAeA,CAACA,CAACA,CAACA;wBACtCA,UAAUA,CAACA,GAAGA,EAAEA,CAACA,GAAGA,eAAeA,CAACA,CAACA,CAACA;wBACtCA,UAAUA,CAACA,GAAGA,EAAEA,CAACA,GAAGA,eAAeA,CAACA,CAACA,CAACA;wBACtCA,UAAUA,CAACA,GAAGA,EAAEA,CAACA,GAAGA,oBAAoBA,CAACA,CAACA,CAACA;wBAC3CA,UAAUA,CAACA,GAAGA,EAAEA,CAACA,GAAGA,oBAAoBA,CAACA,CAACA,CAACA;wBAC3CA,UAAUA,CAACA,GAAGA,EAAEA,CAACA,GAAGA,oBAAoBA,CAACA,CAACA,CAACA;oBAC5CA,CAACA;gBACFA,CAACA;YACFA,CAACA;QACFA,CAACA;QACDA,EAAEA,CAACA,CAACA,OAAOA,CAACA;YACXA,oBAAoBA,CAACA,gBAAgBA,EAAEA,CAACA;IAC1CA,CAACA;IA7ODP,eAAeA;IACDA,yCAAqBA,GAAmBA,CAACA,CAACA;IAExDA,eAAeA;IACDA,yCAAqBA,GAAmBA,CAACA,CAACA;IA2OzDA,0BAACA;AAADA,CAjPA,AAiPCA,EAjPiC,iBAAiB,EAiPlD;AAED,AAA6B,iBAApB,mBAAmB,CAAC","file":"animators/states/ParticleFollowState.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import DisplayObject\t\t\t\t\t= require(\"awayjs-core/lib/core/base/DisplayObject\");\nimport MathConsts\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/MathConsts\");\nimport Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\nimport Camera\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Camera\");\n\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport RenderableBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/RenderableBase\");\nimport ContextGLVertexBufferFormat\t\t= require(\"awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat\");\n\nimport ParticleAnimator\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimator\");\nimport AnimationSubGeometry\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/AnimationSubGeometry\");\nimport ParticleAnimationData\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleAnimationData\");\nimport ParticleFollowNode\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleFollowNode\");\nimport ParticleStateBase\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleStateBase\");\n\n/**\n * ...\n */\nclass ParticleFollowState extends ParticleStateBase\n{\n\t/** @private */\n\tpublic static FOLLOW_POSITION_INDEX:number /*uint*/ = 0;\n\n\t/** @private */\n\tpublic static FOLLOW_ROTATION_INDEX:number /*uint*/ = 1;\n\n\tprivate _particleFollowNode:ParticleFollowNode;\n\tprivate _followTarget:DisplayObject;\n\n\tprivate _targetPos:Vector3D = new Vector3D();\n\tprivate _targetEuler:Vector3D = new Vector3D();\n\tprivate _prePos:Vector3D;\n\tprivate _preEuler:Vector3D;\n\tprivate _smooth:boolean;\n\n\t//temporary vector3D for calculation\n\tprivate _temp:Vector3D = new Vector3D();\n\n\tconstructor(animator:ParticleAnimator, particleFollowNode:ParticleFollowNode)\n\t{\n\t\tsuper(animator, particleFollowNode, true);\n\n\t\tthis._particleFollowNode = particleFollowNode;\n\t\tthis._smooth = particleFollowNode._iSmooth;\n\t}\n\n\tpublic get followTarget():DisplayObject\n\t{\n\t\treturn this._followTarget;\n\t}\n\n\tpublic set followTarget(value:DisplayObject)\n\t{\n\t\tthis._followTarget = value;\n\t}\n\n\tpublic get smooth():boolean\n\t{\n\t\treturn this._smooth;\n\t}\n\n\tpublic set smooth(value:boolean)\n\t{\n\t\tthis._smooth = value;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)\n\t{\n\t\tif (this._followTarget) {\n\t\t\tif (this._particleFollowNode._iUsesPosition) {\n\t\t\t\tthis._targetPos.x = this._followTarget.transform.position.x/renderable.sourceEntity.scaleX;\n\t\t\t\tthis._targetPos.y = this._followTarget.transform.position.y/renderable.sourceEntity.scaleY;\n\t\t\t\tthis._targetPos.z = this._followTarget.transform.position.z/renderable.sourceEntity.scaleZ;\n\t\t\t}\n\t\t\tif (this._particleFollowNode._iUsesRotation) {\n\t\t\t\tthis._targetEuler.x = this._followTarget.rotationX;\n\t\t\t\tthis._targetEuler.y = this._followTarget.rotationY;\n\t\t\t\tthis._targetEuler.z = this._followTarget.rotationZ;\n\t\t\t\tthis._targetEuler.scaleBy(MathConsts.DEGREES_TO_RADIANS);\n\t\t\t}\n\t\t}\n\t\t//initialization\n\t\tif (!this._prePos)\n\t\t\tthis._prePos = this._targetPos.clone();\n\t\tif (!this._preEuler)\n\t\t\tthis._preEuler = this._targetEuler.clone();\n\n\t\tvar currentTime:number = this._pTime/1000;\n\t\tvar previousTime:number = animationSubGeometry.previousTime;\n\t\tvar deltaTime:number = currentTime - previousTime;\n\n\t\tvar needProcess:boolean = previousTime != currentTime;\n\n\t\tif (this._particleFollowNode._iUsesPosition && this._particleFollowNode._iUsesRotation) {\n\t\t\tif (needProcess)\n\t\t\t\tthis.processPositionAndRotation(currentTime, deltaTime, animationSubGeometry);\n\n\t\t\tanimationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleFollowState.FOLLOW_POSITION_INDEX), this._particleFollowNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);\n\t\t\tanimationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleFollowState.FOLLOW_ROTATION_INDEX), this._particleFollowNode._iDataOffset + 3, stage, ContextGLVertexBufferFormat.FLOAT_3);\n\t\t} else if (this._particleFollowNode._iUsesPosition) {\n\t\t\tif (needProcess)\n\t\t\t\tthis.processPosition(currentTime, deltaTime, animationSubGeometry);\n\n\t\t\tanimationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleFollowState.FOLLOW_POSITION_INDEX), this._particleFollowNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);\n\t\t} else if (this._particleFollowNode._iUsesRotation) {\n\t\t\tif (needProcess)\n\t\t\t\tthis.precessRotation(currentTime, deltaTime, animationSubGeometry);\n\n\t\t\tanimationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleFollowState.FOLLOW_ROTATION_INDEX), this._particleFollowNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);\n\t\t}\n\n\t\tthis._prePos.copyFrom(this._targetPos);\n\t\tthis._targetEuler.copyFrom(this._targetEuler);\n\t\tanimationSubGeometry.previousTime = currentTime;\n\t}\n\n\tprivate processPosition(currentTime:number, deltaTime:number, animationSubGeometry:AnimationSubGeometry)\n\t{\n\t\tvar data:Array<ParticleAnimationData> = animationSubGeometry.animationParticles;\n\t\tvar vertexData:Array<number> = animationSubGeometry.vertexData;\n\n\t\tvar changed:boolean = false;\n\t\tvar len:number /*uint*/ = data.length;\n\t\tvar interpolatedPos:Vector3D;\n\t\tvar posVelocity:Vector3D;\n\t\tif (this._smooth) {\n\t\t\tposVelocity = this._prePos.subtract(this._targetPos);\n\t\t\tposVelocity.scaleBy(1/deltaTime);\n\t\t} else\n\t\t\tinterpolatedPos = this._targetPos;\n\t\tfor (var i:number /*uint*/ = 0; i < len; i++) {\n\t\t\tvar k:number = (currentTime - data[i].startTime)/data[i].totalTime;\n\t\t\tvar t:number = (k - Math.floor(k))*data[i].totalTime;\n\t\t\tif (t - deltaTime <= 0) {\n\t\t\t\tvar inc:number /*int*/ = data[i].startVertexIndex*animationSubGeometry.totalLenOfOneVertex + this._particleFollowNode._iDataOffset;\n\n\t\t\t\tif (this._smooth) {\n\t\t\t\t\tthis._temp.copyFrom(posVelocity);\n\t\t\t\t\tthis._temp.scaleBy(t);\n\t\t\t\t\tinterpolatedPos = this._targetPos.add(this._temp);\n\t\t\t\t}\n\n\t\t\t\tif (vertexData[inc] != interpolatedPos.x || vertexData[inc + 1] != interpolatedPos.y || vertexData[inc + 2] != interpolatedPos.z) {\n\t\t\t\t\tchanged = true;\n\t\t\t\t\tfor (var j:number /*uint*/ = 0; j < data[i].numVertices; j++) {\n\t\t\t\t\t\tvertexData[inc++] = interpolatedPos.x;\n\t\t\t\t\t\tvertexData[inc++] = interpolatedPos.y;\n\t\t\t\t\t\tvertexData[inc++] = interpolatedPos.z;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tif (changed)\n\t\t\tanimationSubGeometry.invalidateBuffer();\n\n\t}\n\n\tprivate precessRotation(currentTime:number, deltaTime:number, animationSubGeometry:AnimationSubGeometry)\n\t{\n\t\tvar data:Array<ParticleAnimationData> = animationSubGeometry.animationParticles;\n\t\tvar vertexData:Array<number> = animationSubGeometry.vertexData;\n\n\t\tvar changed:boolean = false;\n\t\tvar len:number /*uint*/ = data.length;\n\n\t\tvar interpolatedRotation:Vector3D;\n\t\tvar rotationVelocity:Vector3D;\n\n\t\tif (this._smooth) {\n\t\t\trotationVelocity = this._preEuler.subtract(this._targetEuler);\n\t\t\trotationVelocity.scaleBy(1/deltaTime);\n\t\t} else\n\t\t\tinterpolatedRotation = this._targetEuler;\n\n\t\tfor (var i:number /*uint*/ = 0; i < len; i++) {\n\t\t\tvar k:number = (currentTime - data[i].startTime)/data[i].totalTime;\n\t\t\tvar t:number = (k - Math.floor(k))*data[i].totalTime;\n\t\t\tif (t - deltaTime <= 0) {\n\t\t\t\tvar inc:number /*int*/ = data[i].startVertexIndex*animationSubGeometry.totalLenOfOneVertex + this._particleFollowNode._iDataOffset;\n\n\t\t\t\tif (this._smooth) {\n\t\t\t\t\tthis._temp.copyFrom(rotationVelocity);\n\t\t\t\t\tthis._temp.scaleBy(t);\n\t\t\t\t\tinterpolatedRotation = this._targetEuler.add(this._temp);\n\t\t\t\t}\n\n\t\t\t\tif (vertexData[inc] != interpolatedRotation.x || vertexData[inc + 1] != interpolatedRotation.y || vertexData[inc + 2] != interpolatedRotation.z) {\n\t\t\t\t\tchanged = true;\n\t\t\t\t\tfor (var j:number /*uint*/ = 0; j < data[i].numVertices; j++) {\n\t\t\t\t\t\tvertexData[inc++] = interpolatedRotation.x;\n\t\t\t\t\t\tvertexData[inc++] = interpolatedRotation.y;\n\t\t\t\t\t\tvertexData[inc++] = interpolatedRotation.z;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tif (changed)\n\t\t\tanimationSubGeometry.invalidateBuffer();\n\n\t}\n\n\tprivate processPositionAndRotation(currentTime:number, deltaTime:number, animationSubGeometry:AnimationSubGeometry)\n\t{\n\t\tvar data:Array<ParticleAnimationData> = animationSubGeometry.animationParticles;\n\t\tvar vertexData:Array<number> = animationSubGeometry.vertexData;\n\n\t\tvar changed:boolean = false;\n\t\tvar len:number /*uint*/ = data.length;\n\n\t\tvar interpolatedPos:Vector3D;\n\t\tvar interpolatedRotation:Vector3D;\n\n\t\tvar posVelocity:Vector3D;\n\t\tvar rotationVelocity:Vector3D;\n\t\tif (this._smooth) {\n\t\t\tposVelocity = this._prePos.subtract(this._targetPos);\n\t\t\tposVelocity.scaleBy(1/deltaTime);\n\t\t\trotationVelocity = this._preEuler.subtract(this._targetEuler);\n\t\t\trotationVelocity.scaleBy(1/deltaTime);\n\t\t} else {\n\t\t\tinterpolatedPos = this._targetPos;\n\t\t\tinterpolatedRotation = this._targetEuler;\n\t\t}\n\n\t\tfor (var i:number /*uint*/ = 0; i < len; i++) {\n\t\t\tvar k:number = (currentTime - data[i].startTime)/data[i].totalTime;\n\t\t\tvar t:number = (k - Math.floor(k))*data[i].totalTime;\n\t\t\tif (t - deltaTime <= 0) {\n\t\t\t\tvar inc:number /*int*/ = data[i].startVertexIndex*animationSubGeometry.totalLenOfOneVertex + this._particleFollowNode._iDataOffset;\n\t\t\t\tif (this._smooth) {\n\t\t\t\t\tthis._temp.copyFrom(posVelocity);\n\t\t\t\t\tthis._temp.scaleBy(t);\n\t\t\t\t\tinterpolatedPos = this._targetPos.add(this._temp);\n\n\t\t\t\t\tthis._temp.copyFrom(rotationVelocity);\n\t\t\t\t\tthis._temp.scaleBy(t);\n\t\t\t\t\tinterpolatedRotation = this._targetEuler.add(this._temp);\n\t\t\t\t}\n\n\t\t\t\tif (vertexData[inc] != interpolatedPos.x || vertexData[inc + 1] != interpolatedPos.y || vertexData[inc + 2] != interpolatedPos.z || vertexData[inc + 3] != interpolatedRotation.x || vertexData[inc + 4] != interpolatedRotation.y || vertexData[inc + 5] != interpolatedRotation.z) {\n\t\t\t\t\tchanged = true;\n\t\t\t\t\tfor (var j:number /*uint*/ = 0; j < data[i].numVertices; j++) {\n\t\t\t\t\t\tvertexData[inc++] = interpolatedPos.x;\n\t\t\t\t\t\tvertexData[inc++] = interpolatedPos.y;\n\t\t\t\t\t\tvertexData[inc++] = interpolatedPos.z;\n\t\t\t\t\t\tvertexData[inc++] = interpolatedRotation.x;\n\t\t\t\t\t\tvertexData[inc++] = interpolatedRotation.y;\n\t\t\t\t\t\tvertexData[inc++] = interpolatedRotation.z;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tif (changed)\n\t\t\tanimationSubGeometry.invalidateBuffer();\n\t}\n\n}\n\nexport = ParticleFollowState;"]}
\ No newline at end of file
diff --git a/lib/animators/states/ParticleFollowState.ts b/lib/animators/states/ParticleFollowState.ts
new file mode 100644
index 000000000..64accfd26
--- /dev/null
+++ b/lib/animators/states/ParticleFollowState.ts
@@ -0,0 +1,263 @@
+import DisplayObject = require("awayjs-core/lib/core/base/DisplayObject");
+import MathConsts = require("awayjs-core/lib/core/geom/MathConsts");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+
+import ParticleAnimator = require("awayjs-renderergl/lib/animators/ParticleAnimator");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticleAnimationData = require("awayjs-renderergl/lib/animators/data/ParticleAnimationData");
+import ParticleFollowNode = require("awayjs-renderergl/lib/animators/nodes/ParticleFollowNode");
+import ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+
+/**
+ * ...
+ */
+class ParticleFollowState extends ParticleStateBase
+{
+ /** @private */
+ public static FOLLOW_POSITION_INDEX:number /*uint*/ = 0;
+
+ /** @private */
+ public static FOLLOW_ROTATION_INDEX:number /*uint*/ = 1;
+
+ private _particleFollowNode:ParticleFollowNode;
+ private _followTarget:DisplayObject;
+
+ private _targetPos:Vector3D = new Vector3D();
+ private _targetEuler:Vector3D = new Vector3D();
+ private _prePos:Vector3D;
+ private _preEuler:Vector3D;
+ private _smooth:boolean;
+
+ //temporary vector3D for calculation
+ private _temp:Vector3D = new Vector3D();
+
+ constructor(animator:ParticleAnimator, particleFollowNode:ParticleFollowNode)
+ {
+ super(animator, particleFollowNode, true);
+
+ this._particleFollowNode = particleFollowNode;
+ this._smooth = particleFollowNode._iSmooth;
+ }
+
+ public get followTarget():DisplayObject
+ {
+ return this._followTarget;
+ }
+
+ public set followTarget(value:DisplayObject)
+ {
+ this._followTarget = value;
+ }
+
+ public get smooth():boolean
+ {
+ return this._smooth;
+ }
+
+ public set smooth(value:boolean)
+ {
+ this._smooth = value;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)
+ {
+ if (this._followTarget) {
+ if (this._particleFollowNode._iUsesPosition) {
+ this._targetPos.x = this._followTarget.transform.position.x/renderable.sourceEntity.scaleX;
+ this._targetPos.y = this._followTarget.transform.position.y/renderable.sourceEntity.scaleY;
+ this._targetPos.z = this._followTarget.transform.position.z/renderable.sourceEntity.scaleZ;
+ }
+ if (this._particleFollowNode._iUsesRotation) {
+ this._targetEuler.x = this._followTarget.rotationX;
+ this._targetEuler.y = this._followTarget.rotationY;
+ this._targetEuler.z = this._followTarget.rotationZ;
+ this._targetEuler.scaleBy(MathConsts.DEGREES_TO_RADIANS);
+ }
+ }
+ //initialization
+ if (!this._prePos)
+ this._prePos = this._targetPos.clone();
+ if (!this._preEuler)
+ this._preEuler = this._targetEuler.clone();
+
+ var currentTime:number = this._pTime/1000;
+ var previousTime:number = animationSubGeometry.previousTime;
+ var deltaTime:number = currentTime - previousTime;
+
+ var needProcess:boolean = previousTime != currentTime;
+
+ if (this._particleFollowNode._iUsesPosition && this._particleFollowNode._iUsesRotation) {
+ if (needProcess)
+ this.processPositionAndRotation(currentTime, deltaTime, animationSubGeometry);
+
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleFollowState.FOLLOW_POSITION_INDEX), this._particleFollowNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleFollowState.FOLLOW_ROTATION_INDEX), this._particleFollowNode._iDataOffset + 3, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ } else if (this._particleFollowNode._iUsesPosition) {
+ if (needProcess)
+ this.processPosition(currentTime, deltaTime, animationSubGeometry);
+
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleFollowState.FOLLOW_POSITION_INDEX), this._particleFollowNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ } else if (this._particleFollowNode._iUsesRotation) {
+ if (needProcess)
+ this.precessRotation(currentTime, deltaTime, animationSubGeometry);
+
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleFollowState.FOLLOW_ROTATION_INDEX), this._particleFollowNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ }
+
+ this._prePos.copyFrom(this._targetPos);
+ this._targetEuler.copyFrom(this._targetEuler);
+ animationSubGeometry.previousTime = currentTime;
+ }
+
+ private processPosition(currentTime:number, deltaTime:number, animationSubGeometry:AnimationSubGeometry)
+ {
+ var data:Array = animationSubGeometry.animationParticles;
+ var vertexData:Array = animationSubGeometry.vertexData;
+
+ var changed:boolean = false;
+ var len:number /*uint*/ = data.length;
+ var interpolatedPos:Vector3D;
+ var posVelocity:Vector3D;
+ if (this._smooth) {
+ posVelocity = this._prePos.subtract(this._targetPos);
+ posVelocity.scaleBy(1/deltaTime);
+ } else
+ interpolatedPos = this._targetPos;
+ for (var i:number /*uint*/ = 0; i < len; i++) {
+ var k:number = (currentTime - data[i].startTime)/data[i].totalTime;
+ var t:number = (k - Math.floor(k))*data[i].totalTime;
+ if (t - deltaTime <= 0) {
+ var inc:number /*int*/ = data[i].startVertexIndex*animationSubGeometry.totalLenOfOneVertex + this._particleFollowNode._iDataOffset;
+
+ if (this._smooth) {
+ this._temp.copyFrom(posVelocity);
+ this._temp.scaleBy(t);
+ interpolatedPos = this._targetPos.add(this._temp);
+ }
+
+ if (vertexData[inc] != interpolatedPos.x || vertexData[inc + 1] != interpolatedPos.y || vertexData[inc + 2] != interpolatedPos.z) {
+ changed = true;
+ for (var j:number /*uint*/ = 0; j < data[i].numVertices; j++) {
+ vertexData[inc++] = interpolatedPos.x;
+ vertexData[inc++] = interpolatedPos.y;
+ vertexData[inc++] = interpolatedPos.z;
+ }
+ }
+ }
+ }
+ if (changed)
+ animationSubGeometry.invalidateBuffer();
+
+ }
+
+ private precessRotation(currentTime:number, deltaTime:number, animationSubGeometry:AnimationSubGeometry)
+ {
+ var data:Array = animationSubGeometry.animationParticles;
+ var vertexData:Array = animationSubGeometry.vertexData;
+
+ var changed:boolean = false;
+ var len:number /*uint*/ = data.length;
+
+ var interpolatedRotation:Vector3D;
+ var rotationVelocity:Vector3D;
+
+ if (this._smooth) {
+ rotationVelocity = this._preEuler.subtract(this._targetEuler);
+ rotationVelocity.scaleBy(1/deltaTime);
+ } else
+ interpolatedRotation = this._targetEuler;
+
+ for (var i:number /*uint*/ = 0; i < len; i++) {
+ var k:number = (currentTime - data[i].startTime)/data[i].totalTime;
+ var t:number = (k - Math.floor(k))*data[i].totalTime;
+ if (t - deltaTime <= 0) {
+ var inc:number /*int*/ = data[i].startVertexIndex*animationSubGeometry.totalLenOfOneVertex + this._particleFollowNode._iDataOffset;
+
+ if (this._smooth) {
+ this._temp.copyFrom(rotationVelocity);
+ this._temp.scaleBy(t);
+ interpolatedRotation = this._targetEuler.add(this._temp);
+ }
+
+ if (vertexData[inc] != interpolatedRotation.x || vertexData[inc + 1] != interpolatedRotation.y || vertexData[inc + 2] != interpolatedRotation.z) {
+ changed = true;
+ for (var j:number /*uint*/ = 0; j < data[i].numVertices; j++) {
+ vertexData[inc++] = interpolatedRotation.x;
+ vertexData[inc++] = interpolatedRotation.y;
+ vertexData[inc++] = interpolatedRotation.z;
+ }
+ }
+ }
+ }
+ if (changed)
+ animationSubGeometry.invalidateBuffer();
+
+ }
+
+ private processPositionAndRotation(currentTime:number, deltaTime:number, animationSubGeometry:AnimationSubGeometry)
+ {
+ var data:Array = animationSubGeometry.animationParticles;
+ var vertexData:Array = animationSubGeometry.vertexData;
+
+ var changed:boolean = false;
+ var len:number /*uint*/ = data.length;
+
+ var interpolatedPos:Vector3D;
+ var interpolatedRotation:Vector3D;
+
+ var posVelocity:Vector3D;
+ var rotationVelocity:Vector3D;
+ if (this._smooth) {
+ posVelocity = this._prePos.subtract(this._targetPos);
+ posVelocity.scaleBy(1/deltaTime);
+ rotationVelocity = this._preEuler.subtract(this._targetEuler);
+ rotationVelocity.scaleBy(1/deltaTime);
+ } else {
+ interpolatedPos = this._targetPos;
+ interpolatedRotation = this._targetEuler;
+ }
+
+ for (var i:number /*uint*/ = 0; i < len; i++) {
+ var k:number = (currentTime - data[i].startTime)/data[i].totalTime;
+ var t:number = (k - Math.floor(k))*data[i].totalTime;
+ if (t - deltaTime <= 0) {
+ var inc:number /*int*/ = data[i].startVertexIndex*animationSubGeometry.totalLenOfOneVertex + this._particleFollowNode._iDataOffset;
+ if (this._smooth) {
+ this._temp.copyFrom(posVelocity);
+ this._temp.scaleBy(t);
+ interpolatedPos = this._targetPos.add(this._temp);
+
+ this._temp.copyFrom(rotationVelocity);
+ this._temp.scaleBy(t);
+ interpolatedRotation = this._targetEuler.add(this._temp);
+ }
+
+ if (vertexData[inc] != interpolatedPos.x || vertexData[inc + 1] != interpolatedPos.y || vertexData[inc + 2] != interpolatedPos.z || vertexData[inc + 3] != interpolatedRotation.x || vertexData[inc + 4] != interpolatedRotation.y || vertexData[inc + 5] != interpolatedRotation.z) {
+ changed = true;
+ for (var j:number /*uint*/ = 0; j < data[i].numVertices; j++) {
+ vertexData[inc++] = interpolatedPos.x;
+ vertexData[inc++] = interpolatedPos.y;
+ vertexData[inc++] = interpolatedPos.z;
+ vertexData[inc++] = interpolatedRotation.x;
+ vertexData[inc++] = interpolatedRotation.y;
+ vertexData[inc++] = interpolatedRotation.z;
+ }
+ }
+ }
+ }
+ if (changed)
+ animationSubGeometry.invalidateBuffer();
+ }
+
+}
+
+export = ParticleFollowState;
\ No newline at end of file
diff --git a/lib/animators/states/ParticleInitialColorState.js b/lib/animators/states/ParticleInitialColorState.js
new file mode 100755
index 000000000..ed230d146
--- /dev/null
+++ b/lib/animators/states/ParticleInitialColorState.js
@@ -0,0 +1,78 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+/**
+*
+*/
+var ParticleInitialColorState = (function (_super) {
+ __extends(ParticleInitialColorState, _super);
+ function ParticleInitialColorState(animator, particleInitialColorNode) {
+ _super.call(this, animator, particleInitialColorNode);
+ this._particleInitialColorNode = particleInitialColorNode;
+ this._usesMultiplier = particleInitialColorNode._iUsesMultiplier;
+ this._usesOffset = particleInitialColorNode._iUsesOffset;
+ this._initialColor = particleInitialColorNode._iInitialColor;
+ this.updateColorData();
+ }
+ Object.defineProperty(ParticleInitialColorState.prototype, "initialColor", {
+ /**
+ * Defines the initial color transform of the state, when in global mode.
+ */
+ get: function () {
+ return this._initialColor;
+ },
+ set: function (value) {
+ this._initialColor = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ ParticleInitialColorState.prototype.setRenderState = function (stage, renderable, animationSubGeometry, animationRegisterCache, camera) {
+ // TODO: not used
+ renderable = renderable;
+ camera = camera;
+ if (animationRegisterCache.needFragmentAnimation) {
+ if (this._particleInitialColorNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {
+ var dataOffset = this._particleInitialColorNode._iDataOffset;
+ if (this._usesMultiplier) {
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleInitialColorState.MULTIPLIER_INDEX), dataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ dataOffset += 4;
+ }
+ if (this._usesOffset)
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleInitialColorState.OFFSET_INDEX), dataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ }
+ else {
+ if (this._usesMultiplier)
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleInitialColorState.MULTIPLIER_INDEX), this._multiplierData.x, this._multiplierData.y, this._multiplierData.z, this._multiplierData.w);
+ if (this._usesOffset)
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleInitialColorState.OFFSET_INDEX), this._offsetData.x, this._offsetData.y, this._offsetData.z, this._offsetData.w);
+ }
+ }
+ };
+ ParticleInitialColorState.prototype.updateColorData = function () {
+ if (this._particleInitialColorNode.mode == ParticlePropertiesMode.GLOBAL) {
+ if (this._usesMultiplier)
+ this._multiplierData = new Vector3D(this._initialColor.redMultiplier, this._initialColor.greenMultiplier, this._initialColor.blueMultiplier, this._initialColor.alphaMultiplier);
+ if (this._usesOffset)
+ this._offsetData = new Vector3D(this._initialColor.redOffset / 255, this._initialColor.greenOffset / 255, this._initialColor.blueOffset / 255, this._initialColor.alphaOffset / 255);
+ }
+ };
+ /** @private */
+ ParticleInitialColorState.MULTIPLIER_INDEX = 0;
+ /** @private */
+ ParticleInitialColorState.OFFSET_INDEX = 1;
+ return ParticleInitialColorState;
+})(ParticleStateBase);
+module.exports = ParticleInitialColorState;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/states/particleinitialcolorstate.ts"],"names":["ParticleInitialColorState","ParticleInitialColorState.constructor","ParticleInitialColorState.initialColor","ParticleInitialColorState.setRenderState","ParticleInitialColorState.updateColorData"],"mappings":"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","file":"animators/states/ParticleInitialColorState.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import ColorTransform\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/ColorTransform\");\nimport Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\nimport Camera\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Camera\");\n\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport RenderableBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/RenderableBase\");\nimport ContextGLVertexBufferFormat\t\t= require(\"awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat\");\n\nimport ParticleAnimator\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimator\");\nimport AnimationSubGeometry\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/AnimationSubGeometry\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleInitialColorNode\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleInitialColorNode\");\nimport ParticleStateBase\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleStateBase\");\n\n/**\n*\n*/\nclass ParticleInitialColorState extends ParticleStateBase\n{\n\t/** @private */\n\tpublic static MULTIPLIER_INDEX:number /*uint*/ = 0;\n\t/** @private */\n\tpublic static OFFSET_INDEX:number /*uint*/ = 1;\n\n\tprivate _particleInitialColorNode:ParticleInitialColorNode;\n\tprivate _usesMultiplier:boolean;\n\tprivate _usesOffset:boolean;\n\tprivate _initialColor:ColorTransform;\n\tprivate _multiplierData:Vector3D;\n\tprivate _offsetData:Vector3D;\n\n\tconstructor(animator:ParticleAnimator, particleInitialColorNode:ParticleInitialColorNode)\n\t{\n\t\tsuper(animator, particleInitialColorNode);\n\n\t\tthis._particleInitialColorNode = particleInitialColorNode;\n\t\tthis._usesMultiplier = particleInitialColorNode._iUsesMultiplier;\n\t\tthis._usesOffset = particleInitialColorNode._iUsesOffset;\n\t\tthis._initialColor = particleInitialColorNode._iInitialColor;\n\n\t\tthis.updateColorData();\n\t}\n\n\t/**\n\t * Defines the initial color transform of the state, when in global mode.\n\t */\n\tpublic get initialColor():ColorTransform\n\t{\n\t\treturn this._initialColor;\n\t}\n\n\tpublic set initialColor(value:ColorTransform)\n\t{\n\t\tthis._initialColor = value;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)\n\t{\n\t\t// TODO: not used\n\t\trenderable = renderable;\n\t\tcamera = camera;\n\n\t\tif (animationRegisterCache.needFragmentAnimation) {\n\t\t\tif (this._particleInitialColorNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {\n\t\t\t\tvar dataOffset:number /*uint*/ = this._particleInitialColorNode._iDataOffset;\n\t\t\t\tif (this._usesMultiplier) {\n\t\t\t\t\tanimationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleInitialColorState.MULTIPLIER_INDEX), dataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);\n\t\t\t\t\tdataOffset += 4;\n\t\t\t\t}\n\t\t\t\tif (this._usesOffset)\n\t\t\t\t\tanimationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleInitialColorState.OFFSET_INDEX), dataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);\n\t\t\t} else {\n\t\t\t\tif (this._usesMultiplier)\n\t\t\t\t\tanimationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleInitialColorState.MULTIPLIER_INDEX), this._multiplierData.x, this._multiplierData.y, this._multiplierData.z, this._multiplierData.w);\n\t\t\t\tif (this._usesOffset)\n\t\t\t\t\tanimationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleInitialColorState.OFFSET_INDEX), this._offsetData.x, this._offsetData.y, this._offsetData.z, this._offsetData.w);\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate updateColorData()\n\t{\n\t\tif (this._particleInitialColorNode.mode == ParticlePropertiesMode.GLOBAL) {\n\t\t\tif (this._usesMultiplier)\n\t\t\t\tthis._multiplierData = new Vector3D(this._initialColor.redMultiplier, this._initialColor.greenMultiplier, this._initialColor.blueMultiplier, this._initialColor.alphaMultiplier);\n\t\t\tif (this._usesOffset)\n\t\t\t\tthis._offsetData = new Vector3D(this._initialColor.redOffset/255, this._initialColor.greenOffset/255, this._initialColor.blueOffset/255, this._initialColor.alphaOffset/255);\n\t\t}\n\t}\n\n}\n\nexport = ParticleInitialColorState;"]}
\ No newline at end of file
diff --git a/lib/animators/states/ParticleInitialColorState.ts b/lib/animators/states/ParticleInitialColorState.ts
new file mode 100644
index 000000000..55964ce92
--- /dev/null
+++ b/lib/animators/states/ParticleInitialColorState.ts
@@ -0,0 +1,97 @@
+import ColorTransform = require("awayjs-core/lib/core/geom/ColorTransform");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+
+import ParticleAnimator = require("awayjs-renderergl/lib/animators/ParticleAnimator");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleInitialColorNode = require("awayjs-renderergl/lib/animators/nodes/ParticleInitialColorNode");
+import ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+
+/**
+*
+*/
+class ParticleInitialColorState extends ParticleStateBase
+{
+ /** @private */
+ public static MULTIPLIER_INDEX:number /*uint*/ = 0;
+ /** @private */
+ public static OFFSET_INDEX:number /*uint*/ = 1;
+
+ private _particleInitialColorNode:ParticleInitialColorNode;
+ private _usesMultiplier:boolean;
+ private _usesOffset:boolean;
+ private _initialColor:ColorTransform;
+ private _multiplierData:Vector3D;
+ private _offsetData:Vector3D;
+
+ constructor(animator:ParticleAnimator, particleInitialColorNode:ParticleInitialColorNode)
+ {
+ super(animator, particleInitialColorNode);
+
+ this._particleInitialColorNode = particleInitialColorNode;
+ this._usesMultiplier = particleInitialColorNode._iUsesMultiplier;
+ this._usesOffset = particleInitialColorNode._iUsesOffset;
+ this._initialColor = particleInitialColorNode._iInitialColor;
+
+ this.updateColorData();
+ }
+
+ /**
+ * Defines the initial color transform of the state, when in global mode.
+ */
+ public get initialColor():ColorTransform
+ {
+ return this._initialColor;
+ }
+
+ public set initialColor(value:ColorTransform)
+ {
+ this._initialColor = value;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)
+ {
+ // TODO: not used
+ renderable = renderable;
+ camera = camera;
+
+ if (animationRegisterCache.needFragmentAnimation) {
+ if (this._particleInitialColorNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {
+ var dataOffset:number /*uint*/ = this._particleInitialColorNode._iDataOffset;
+ if (this._usesMultiplier) {
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleInitialColorState.MULTIPLIER_INDEX), dataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ dataOffset += 4;
+ }
+ if (this._usesOffset)
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleInitialColorState.OFFSET_INDEX), dataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ } else {
+ if (this._usesMultiplier)
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleInitialColorState.MULTIPLIER_INDEX), this._multiplierData.x, this._multiplierData.y, this._multiplierData.z, this._multiplierData.w);
+ if (this._usesOffset)
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleInitialColorState.OFFSET_INDEX), this._offsetData.x, this._offsetData.y, this._offsetData.z, this._offsetData.w);
+ }
+ }
+ }
+
+ private updateColorData()
+ {
+ if (this._particleInitialColorNode.mode == ParticlePropertiesMode.GLOBAL) {
+ if (this._usesMultiplier)
+ this._multiplierData = new Vector3D(this._initialColor.redMultiplier, this._initialColor.greenMultiplier, this._initialColor.blueMultiplier, this._initialColor.alphaMultiplier);
+ if (this._usesOffset)
+ this._offsetData = new Vector3D(this._initialColor.redOffset/255, this._initialColor.greenOffset/255, this._initialColor.blueOffset/255, this._initialColor.alphaOffset/255);
+ }
+ }
+
+}
+
+export = ParticleInitialColorState;
\ No newline at end of file
diff --git a/lib/animators/states/ParticleOrbitState.js b/lib/animators/states/ParticleOrbitState.js
new file mode 100755
index 000000000..2386c8702
--- /dev/null
+++ b/lib/animators/states/ParticleOrbitState.js
@@ -0,0 +1,124 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Matrix3D = require("awayjs-core/lib/core/geom/Matrix3D");
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+/**
+ * ...
+ */
+var ParticleOrbitState = (function (_super) {
+ __extends(ParticleOrbitState, _super);
+ function ParticleOrbitState(animator, particleOrbitNode) {
+ _super.call(this, animator, particleOrbitNode);
+ this._particleOrbitNode = particleOrbitNode;
+ this._usesEulers = this._particleOrbitNode._iUsesEulers;
+ this._usesCycle = this._particleOrbitNode._iUsesCycle;
+ this._usesPhase = this._particleOrbitNode._iUsesPhase;
+ this._eulers = this._particleOrbitNode._iEulers;
+ this._radius = this._particleOrbitNode._iRadius;
+ this._cycleDuration = this._particleOrbitNode._iCycleDuration;
+ this._cyclePhase = this._particleOrbitNode._iCyclePhase;
+ this.updateOrbitData();
+ }
+ Object.defineProperty(ParticleOrbitState.prototype, "radius", {
+ /**
+ * Defines the radius of the orbit when in global mode. Defaults to 100.
+ */
+ get: function () {
+ return this._radius;
+ },
+ set: function (value) {
+ this._radius = value;
+ this.updateOrbitData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleOrbitState.prototype, "cycleDuration", {
+ /**
+ * Defines the duration of the orbit in seconds, used as a period independent of particle duration when in global mode. Defaults to 1.
+ */
+ get: function () {
+ return this._cycleDuration;
+ },
+ set: function (value) {
+ this._cycleDuration = value;
+ this.updateOrbitData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleOrbitState.prototype, "cyclePhase", {
+ /**
+ * Defines the phase of the orbit in degrees, used as the starting offset of the cycle when in global mode. Defaults to 0.
+ */
+ get: function () {
+ return this._cyclePhase;
+ },
+ set: function (value) {
+ this._cyclePhase = value;
+ this.updateOrbitData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleOrbitState.prototype, "eulers", {
+ /**
+ * Defines the euler rotation in degrees, applied to the orientation of the orbit when in global mode.
+ */
+ get: function () {
+ return this._eulers;
+ },
+ set: function (value) {
+ this._eulers = value;
+ this.updateOrbitData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ ParticleOrbitState.prototype.setRenderState = function (stage, renderable, animationSubGeometry, animationRegisterCache, camera) {
+ var index = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleOrbitState.ORBIT_INDEX);
+ if (this._particleOrbitNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {
+ if (this._usesPhase)
+ animationSubGeometry.activateVertexBuffer(index, this._particleOrbitNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ else
+ animationSubGeometry.activateVertexBuffer(index, this._particleOrbitNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ }
+ else
+ animationRegisterCache.setVertexConst(index, this._orbitData.x, this._orbitData.y, this._orbitData.z, this._orbitData.w);
+ if (this._usesEulers)
+ animationRegisterCache.setVertexConstFromMatrix(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleOrbitState.EULERS_INDEX), this._eulersMatrix);
+ };
+ ParticleOrbitState.prototype.updateOrbitData = function () {
+ if (this._usesEulers) {
+ this._eulersMatrix = new Matrix3D();
+ this._eulersMatrix.appendRotation(this._eulers.x, Vector3D.X_AXIS);
+ this._eulersMatrix.appendRotation(this._eulers.y, Vector3D.Y_AXIS);
+ this._eulersMatrix.appendRotation(this._eulers.z, Vector3D.Z_AXIS);
+ }
+ if (this._particleOrbitNode.mode == ParticlePropertiesMode.GLOBAL) {
+ this._orbitData = new Vector3D(this._radius, 0, this._radius * Math.PI * 2, this._cyclePhase * Math.PI / 180);
+ if (this._usesCycle) {
+ if (this._cycleDuration <= 0)
+ throw (new Error("the cycle duration must be greater than zero"));
+ this._orbitData.y = Math.PI * 2 / this._cycleDuration;
+ }
+ else
+ this._orbitData.y = Math.PI * 2;
+ }
+ };
+ /** @private */
+ ParticleOrbitState.ORBIT_INDEX = 0;
+ /** @private */
+ ParticleOrbitState.EULERS_INDEX = 1;
+ return ParticleOrbitState;
+})(ParticleStateBase);
+module.exports = ParticleOrbitState;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/states/particleorbitstate.ts"],"names":["ParticleOrbitState","ParticleOrbitState.constructor","ParticleOrbitState.radius","ParticleOrbitState.cycleDuration","ParticleOrbitState.cyclePhase","ParticleOrbitState.eulers","ParticleOrbitState.setRenderState","ParticleOrbitState.updateOrbitData"],"mappings":";;;;;;AAAA,IAAO,QAAQ,WAAiB,oCAAoC,CAAC,CAAC;AACtE,IAAO,QAAQ,WAAiB,oCAAoC,CAAC,CAAC;AAMtE,IAAO,2BAA2B,WAAY,6DAA6D,CAAC,CAAC;AAI7G,IAAO,sBAAsB,WAAa,6DAA6D,CAAC,CAAC;AAEzG,IAAO,iBAAiB,WAAc,0DAA0D,CAAC,CAAC;AAElG,AAGA;;GADG;IACG,kBAAkB;IAASA,UAA3BA,kBAAkBA,UAA0BA;IAgFjDA,SAhFKA,kBAAkBA,CAgFXA,QAAyBA,EAAEA,iBAAmCA;QAEzEC,kBAAMA,QAAQA,EAAEA,iBAAiBA,CAACA,CAACA;QAEnCA,IAAIA,CAACA,kBAAkBA,GAAGA,iBAAiBA,CAACA;QAC5CA,IAAIA,CAACA,WAAWA,GAAGA,IAAIA,CAACA,kBAAkBA,CAACA,YAAYA,CAACA;QACxDA,IAAIA,CAACA,UAAUA,GAAGA,IAAIA,CAACA,kBAAkBA,CAACA,WAAWA,CAACA;QACtDA,IAAIA,CAACA,UAAUA,GAAGA,IAAIA,CAACA,kBAAkBA,CAACA,WAAWA,CAACA;QACtDA,IAAIA,CAACA,OAAOA,GAAGA,IAAIA,CAACA,kBAAkBA,CAACA,QAAQA,CAACA;QAChDA,IAAIA,CAACA,OAAOA,GAAGA,IAAIA,CAACA,kBAAkBA,CAACA,QAAQA,CAACA;QAChDA,IAAIA,CAACA,cAAcA,GAAGA,IAAIA,CAACA,kBAAkBA,CAACA,eAAeA,CAACA;QAC9DA,IAAIA,CAACA,WAAWA,GAAGA,IAAIA,CAACA,kBAAkBA,CAACA,YAAYA,CAACA;QACxDA,IAAIA,CAACA,eAAeA,EAAEA,CAACA;IACxBA,CAACA;IAvEDD,sBAAWA,sCAAMA;QAHjBA;;WAEGA;aACHA;YAECE,MAAMA,CAACA,IAAIA,CAACA,OAAOA,CAACA;QACrBA,CAACA;aAEDF,UAAkBA,KAAYA;YAE7BE,IAAIA,CAACA,OAAOA,GAAGA,KAAKA,CAACA;YAErBA,IAAIA,CAACA,eAAeA,EAAEA,CAACA;QACxBA,CAACA;;;OAPAF;IAYDA,sBAAWA,6CAAaA;QAHxBA;;WAEGA;aACHA;YAECG,MAAMA,CAACA,IAAIA,CAACA,cAAcA,CAACA;QAC5BA,CAACA;aAEDH,UAAyBA,KAAYA;YAEpCG,IAAIA,CAACA,cAAcA,GAAGA,KAAKA,CAACA;YAE5BA,IAAIA,CAACA,eAAeA,EAAEA,CAACA;QACxBA,CAACA;;;OAPAH;IAYDA,sBAAWA,0CAAUA;QAHrBA;;WAEGA;aACHA;YAECI,MAAMA,CAACA,IAAIA,CAACA,WAAWA,CAACA;QACzBA,CAACA;aAEDJ,UAAsBA,KAAYA;YAEjCI,IAAIA,CAACA,WAAWA,GAAGA,KAAKA,CAACA;YAEzBA,IAAIA,CAACA,eAAeA,EAAEA,CAACA;QACxBA,CAACA;;;OAPAJ;IAYDA,sBAAWA,sCAAMA;QAHjBA;;WAEGA;aACHA;YAECK,MAAMA,CAACA,IAAIA,CAACA,OAAOA,CAACA;QACrBA,CAACA;aAEDL,UAAkBA,KAAcA;YAE/BK,IAAIA,CAACA,OAAOA,GAAGA,KAAKA,CAACA;YAErBA,IAAIA,CAACA,eAAeA,EAAEA,CAACA;QAExBA,CAACA;;;OARAL;IAyBMA,2CAAcA,GAArBA,UAAsBA,KAAWA,EAAEA,UAAyBA,EAAEA,oBAAyCA,EAAEA,sBAA6CA,EAAEA,MAAaA;QAEpKM,IAAIA,KAAKA,GAAkBA,sBAAsBA,CAACA,gBAAgBA,CAACA,IAAIA,CAACA,eAAeA,EAAEA,kBAAkBA,CAACA,WAAWA,CAACA,CAACA;QAEzHA,EAAEA,CAACA,CAACA,IAAIA,CAACA,kBAAkBA,CAACA,IAAIA,IAAIA,sBAAsBA,CAACA,YAAYA,CAACA,CAACA,CAACA;YACzEA,EAAEA,CAACA,CAACA,IAAIA,CAACA,UAAUA,CAACA;gBACnBA,oBAAoBA,CAACA,oBAAoBA,CAACA,KAAKA,EAAEA,IAAIA,CAACA,kBAAkBA,CAACA,YAAYA,EAAEA,KAAKA,EAAEA,2BAA2BA,CAACA,OAAOA,CAACA,CAACA;YACpIA,IAAIA;gBACHA,oBAAoBA,CAACA,oBAAoBA,CAACA,KAAKA,EAAEA,IAAIA,CAACA,kBAAkBA,CAACA,YAAYA,EAAEA,KAAKA,EAAEA,2BAA2BA,CAACA,OAAOA,CAACA,CAACA;QACrIA,CAACA;QAACA,IAAIA;YACLA,sBAAsBA,CAACA,cAAcA,CAACA,KAAKA,EAAEA,IAAIA,CAACA,UAAUA,CAACA,CAACA,EAAEA,IAAIA,CAACA,UAAUA,CAACA,CAACA,EAAEA,IAAIA,CAACA,UAAUA,CAACA,CAACA,EAAEA,IAAIA,CAACA,UAAUA,CAACA,CAACA,CAACA,CAACA;QAE1HA,EAAEA,CAACA,CAACA,IAAIA,CAACA,WAAWA,CAACA;YACpBA,sBAAsBA,CAACA,wBAAwBA,CAACA,sBAAsBA,CAACA,gBAAgBA,CAACA,IAAIA,CAACA,eAAeA,EAAEA,kBAAkBA,CAACA,YAAYA,CAACA,EAAEA,IAAIA,CAACA,aAAaA,CAACA,CAACA;IACtKA,CAACA;IAEON,4CAAeA,GAAvBA;QAECO,EAAEA,CAACA,CAACA,IAAIA,CAACA,WAAWA,CAACA,CAACA,CAACA;YACtBA,IAAIA,CAACA,aAAaA,GAAGA,IAAIA,QAAQA,EAAEA,CAACA;YACpCA,IAAIA,CAACA,aAAaA,CAACA,cAAcA,CAACA,IAAIA,CAACA,OAAOA,CAACA,CAACA,EAAEA,QAAQA,CAACA,MAAMA,CAACA,CAACA;YACnEA,IAAIA,CAACA,aAAaA,CAACA,cAAcA,CAACA,IAAIA,CAACA,OAAOA,CAACA,CAACA,EAAEA,QAAQA,CAACA,MAAMA,CAACA,CAACA;YACnEA,IAAIA,CAACA,aAAaA,CAACA,cAAcA,CAACA,IAAIA,CAACA,OAAOA,CAACA,CAACA,EAAEA,QAAQA,CAACA,MAAMA,CAACA,CAACA;QACpEA,CAACA;QACDA,EAAEA,CAACA,CAACA,IAAIA,CAACA,kBAAkBA,CAACA,IAAIA,IAAIA,sBAAsBA,CAACA,MAAMA,CAACA,CAACA,CAACA;YACnEA,IAAIA,CAACA,UAAUA,GAAGA,IAAIA,QAAQA,CAACA,IAAIA,CAACA,OAAOA,EAAEA,CAACA,EAAEA,IAAIA,CAACA,OAAOA,GAACA,IAAIA,CAACA,EAAEA,GAACA,CAACA,EAAEA,IAAIA,CAACA,WAAWA,GAACA,IAAIA,CAACA,EAAEA,GAACA,GAAGA,CAACA,CAACA;YACtGA,EAAEA,CAACA,CAACA,IAAIA,CAACA,UAAUA,CAACA,CAACA,CAACA;gBACrBA,EAAEA,CAACA,CAACA,IAAIA,CAACA,cAAcA,IAAIA,CAACA,CAACA;oBAC5BA,MAAKA,CAACA,IAAIA,KAAKA,CAACA,8CAA8CA,CAACA,CAACA,CAACA;gBAClEA,IAAIA,CAACA,UAAUA,CAACA,CAACA,GAAGA,IAAIA,CAACA,EAAEA,GAACA,CAACA,GAACA,IAAIA,CAACA,cAAcA,CAACA;YACnDA,CAACA;YAACA,IAAIA;gBACLA,IAAIA,CAACA,UAAUA,CAACA,CAACA,GAAGA,IAAIA,CAACA,EAAEA,GAACA,CAACA,CAACA;QAChCA,CAACA;IACFA,CAACA;IA9HDP,eAAeA;IACDA,8BAAWA,GAAmBA,CAACA,CAACA;IAE9CA,eAAeA;IACDA,+BAAYA,GAAmBA,CAACA,CAACA;IA2HhDA,yBAACA;AAADA,CAjIA,AAiICA,EAjIgC,iBAAiB,EAiIjD;AAED,AAA4B,iBAAnB,kBAAkB,CAAC","file":"animators/states/ParticleOrbitState.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Matrix3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Matrix3D\");\nimport Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\nimport Camera\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Camera\");\n\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport RenderableBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/RenderableBase\");\nimport ContextGLVertexBufferFormat\t\t= require(\"awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat\");\n\nimport ParticleAnimator\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimator\");\nimport AnimationSubGeometry\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/AnimationSubGeometry\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleOrbitNode\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleOrbitNode\");\nimport ParticleStateBase\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleStateBase\");\n\n/**\n * ...\n */\nclass ParticleOrbitState extends ParticleStateBase\n{\n\t/** @private */\n\tpublic static ORBIT_INDEX:number /*uint*/ = 0;\n\n\t/** @private */\n\tpublic static EULERS_INDEX:number /*uint*/ = 1;\n\n\tprivate _particleOrbitNode:ParticleOrbitNode;\n\tprivate _usesEulers:boolean;\n\tprivate _usesCycle:boolean;\n\tprivate _usesPhase:boolean;\n\tprivate _radius:number;\n\tprivate _cycleDuration:number;\n\tprivate _cyclePhase:number;\n\tprivate _eulers:Vector3D;\n\tprivate _orbitData:Vector3D;\n\tprivate _eulersMatrix:Matrix3D;\n\n\t/**\n\t * Defines the radius of the orbit when in global mode. Defaults to 100.\n\t */\n\tpublic get radius():number\n\t{\n\t\treturn this._radius;\n\t}\n\n\tpublic set radius(value:number)\n\t{\n\t\tthis._radius = value;\n\n\t\tthis.updateOrbitData();\n\t}\n\n\t/**\n\t * Defines the duration of the orbit in seconds, used as a period independent of particle duration when in global mode. Defaults to 1.\n\t */\n\tpublic get cycleDuration():number\n\t{\n\t\treturn this._cycleDuration;\n\t}\n\n\tpublic set cycleDuration(value:number)\n\t{\n\t\tthis._cycleDuration = value;\n\n\t\tthis.updateOrbitData();\n\t}\n\n\t/**\n\t * Defines the phase of the orbit in degrees, used as the starting offset of the cycle when in global mode. Defaults to 0.\n\t */\n\tpublic get cyclePhase():number\n\t{\n\t\treturn this._cyclePhase;\n\t}\n\n\tpublic set cyclePhase(value:number)\n\t{\n\t\tthis._cyclePhase = value;\n\n\t\tthis.updateOrbitData();\n\t}\n\n\t/**\n\t * Defines the euler rotation in degrees, applied to the orientation of the orbit when in global mode.\n\t */\n\tpublic get eulers():Vector3D\n\t{\n\t\treturn this._eulers;\n\t}\n\n\tpublic set eulers(value:Vector3D)\n\t{\n\t\tthis._eulers = value;\n\n\t\tthis.updateOrbitData();\n\n\t}\n\n\tconstructor(animator:ParticleAnimator, particleOrbitNode:ParticleOrbitNode)\n\t{\n\t\tsuper(animator, particleOrbitNode);\n\n\t\tthis._particleOrbitNode = particleOrbitNode;\n\t\tthis._usesEulers = this._particleOrbitNode._iUsesEulers;\n\t\tthis._usesCycle = this._particleOrbitNode._iUsesCycle;\n\t\tthis._usesPhase = this._particleOrbitNode._iUsesPhase;\n\t\tthis._eulers = this._particleOrbitNode._iEulers;\n\t\tthis._radius = this._particleOrbitNode._iRadius;\n\t\tthis._cycleDuration = this._particleOrbitNode._iCycleDuration;\n\t\tthis._cyclePhase = this._particleOrbitNode._iCyclePhase;\n\t\tthis.updateOrbitData();\n\t}\n\n\tpublic setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)\n\t{\n\t\tvar index:number /*int*/ = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleOrbitState.ORBIT_INDEX);\n\n\t\tif (this._particleOrbitNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {\n\t\t\tif (this._usesPhase)\n\t\t\t\tanimationSubGeometry.activateVertexBuffer(index, this._particleOrbitNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);\n\t\t\telse\n\t\t\t\tanimationSubGeometry.activateVertexBuffer(index, this._particleOrbitNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);\n\t\t} else\n\t\t\tanimationRegisterCache.setVertexConst(index, this._orbitData.x, this._orbitData.y, this._orbitData.z, this._orbitData.w);\n\n\t\tif (this._usesEulers)\n\t\t\tanimationRegisterCache.setVertexConstFromMatrix(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleOrbitState.EULERS_INDEX), this._eulersMatrix);\n\t}\n\n\tprivate updateOrbitData()\n\t{\n\t\tif (this._usesEulers) {\n\t\t\tthis._eulersMatrix = new Matrix3D();\n\t\t\tthis._eulersMatrix.appendRotation(this._eulers.x, Vector3D.X_AXIS);\n\t\t\tthis._eulersMatrix.appendRotation(this._eulers.y, Vector3D.Y_AXIS);\n\t\t\tthis._eulersMatrix.appendRotation(this._eulers.z, Vector3D.Z_AXIS);\n\t\t}\n\t\tif (this._particleOrbitNode.mode == ParticlePropertiesMode.GLOBAL) {\n\t\t\tthis._orbitData = new Vector3D(this._radius, 0, this._radius*Math.PI*2, this._cyclePhase*Math.PI/180);\n\t\t\tif (this._usesCycle) {\n\t\t\t\tif (this._cycleDuration <= 0)\n\t\t\t\t\tthrow(new Error(\"the cycle duration must be greater than zero\"));\n\t\t\t\tthis._orbitData.y = Math.PI*2/this._cycleDuration;\n\t\t\t} else\n\t\t\t\tthis._orbitData.y = Math.PI*2;\n\t\t}\n\t}\n}\n\nexport = ParticleOrbitState;"]}
\ No newline at end of file
diff --git a/lib/animators/states/ParticleOrbitState.ts b/lib/animators/states/ParticleOrbitState.ts
new file mode 100644
index 000000000..2153843f0
--- /dev/null
+++ b/lib/animators/states/ParticleOrbitState.ts
@@ -0,0 +1,150 @@
+import Matrix3D = require("awayjs-core/lib/core/geom/Matrix3D");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+
+import ParticleAnimator = require("awayjs-renderergl/lib/animators/ParticleAnimator");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleOrbitNode = require("awayjs-renderergl/lib/animators/nodes/ParticleOrbitNode");
+import ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+
+/**
+ * ...
+ */
+class ParticleOrbitState extends ParticleStateBase
+{
+ /** @private */
+ public static ORBIT_INDEX:number /*uint*/ = 0;
+
+ /** @private */
+ public static EULERS_INDEX:number /*uint*/ = 1;
+
+ private _particleOrbitNode:ParticleOrbitNode;
+ private _usesEulers:boolean;
+ private _usesCycle:boolean;
+ private _usesPhase:boolean;
+ private _radius:number;
+ private _cycleDuration:number;
+ private _cyclePhase:number;
+ private _eulers:Vector3D;
+ private _orbitData:Vector3D;
+ private _eulersMatrix:Matrix3D;
+
+ /**
+ * Defines the radius of the orbit when in global mode. Defaults to 100.
+ */
+ public get radius():number
+ {
+ return this._radius;
+ }
+
+ public set radius(value:number)
+ {
+ this._radius = value;
+
+ this.updateOrbitData();
+ }
+
+ /**
+ * Defines the duration of the orbit in seconds, used as a period independent of particle duration when in global mode. Defaults to 1.
+ */
+ public get cycleDuration():number
+ {
+ return this._cycleDuration;
+ }
+
+ public set cycleDuration(value:number)
+ {
+ this._cycleDuration = value;
+
+ this.updateOrbitData();
+ }
+
+ /**
+ * Defines the phase of the orbit in degrees, used as the starting offset of the cycle when in global mode. Defaults to 0.
+ */
+ public get cyclePhase():number
+ {
+ return this._cyclePhase;
+ }
+
+ public set cyclePhase(value:number)
+ {
+ this._cyclePhase = value;
+
+ this.updateOrbitData();
+ }
+
+ /**
+ * Defines the euler rotation in degrees, applied to the orientation of the orbit when in global mode.
+ */
+ public get eulers():Vector3D
+ {
+ return this._eulers;
+ }
+
+ public set eulers(value:Vector3D)
+ {
+ this._eulers = value;
+
+ this.updateOrbitData();
+
+ }
+
+ constructor(animator:ParticleAnimator, particleOrbitNode:ParticleOrbitNode)
+ {
+ super(animator, particleOrbitNode);
+
+ this._particleOrbitNode = particleOrbitNode;
+ this._usesEulers = this._particleOrbitNode._iUsesEulers;
+ this._usesCycle = this._particleOrbitNode._iUsesCycle;
+ this._usesPhase = this._particleOrbitNode._iUsesPhase;
+ this._eulers = this._particleOrbitNode._iEulers;
+ this._radius = this._particleOrbitNode._iRadius;
+ this._cycleDuration = this._particleOrbitNode._iCycleDuration;
+ this._cyclePhase = this._particleOrbitNode._iCyclePhase;
+ this.updateOrbitData();
+ }
+
+ public setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)
+ {
+ var index:number /*int*/ = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleOrbitState.ORBIT_INDEX);
+
+ if (this._particleOrbitNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {
+ if (this._usesPhase)
+ animationSubGeometry.activateVertexBuffer(index, this._particleOrbitNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ else
+ animationSubGeometry.activateVertexBuffer(index, this._particleOrbitNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ } else
+ animationRegisterCache.setVertexConst(index, this._orbitData.x, this._orbitData.y, this._orbitData.z, this._orbitData.w);
+
+ if (this._usesEulers)
+ animationRegisterCache.setVertexConstFromMatrix(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleOrbitState.EULERS_INDEX), this._eulersMatrix);
+ }
+
+ private updateOrbitData()
+ {
+ if (this._usesEulers) {
+ this._eulersMatrix = new Matrix3D();
+ this._eulersMatrix.appendRotation(this._eulers.x, Vector3D.X_AXIS);
+ this._eulersMatrix.appendRotation(this._eulers.y, Vector3D.Y_AXIS);
+ this._eulersMatrix.appendRotation(this._eulers.z, Vector3D.Z_AXIS);
+ }
+ if (this._particleOrbitNode.mode == ParticlePropertiesMode.GLOBAL) {
+ this._orbitData = new Vector3D(this._radius, 0, this._radius*Math.PI*2, this._cyclePhase*Math.PI/180);
+ if (this._usesCycle) {
+ if (this._cycleDuration <= 0)
+ throw(new Error("the cycle duration must be greater than zero"));
+ this._orbitData.y = Math.PI*2/this._cycleDuration;
+ } else
+ this._orbitData.y = Math.PI*2;
+ }
+ }
+}
+
+export = ParticleOrbitState;
\ No newline at end of file
diff --git a/lib/animators/states/ParticleOscillatorState.js b/lib/animators/states/ParticleOscillatorState.js
new file mode 100755
index 000000000..987c0662e
--- /dev/null
+++ b/lib/animators/states/ParticleOscillatorState.js
@@ -0,0 +1,64 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+/**
+ * ...
+ */
+var ParticleOscillatorState = (function (_super) {
+ __extends(ParticleOscillatorState, _super);
+ function ParticleOscillatorState(animator, particleOscillatorNode) {
+ _super.call(this, animator, particleOscillatorNode);
+ this._particleOscillatorNode = particleOscillatorNode;
+ this._oscillator = this._particleOscillatorNode._iOscillator;
+ this.updateOscillatorData();
+ }
+ Object.defineProperty(ParticleOscillatorState.prototype, "oscillator", {
+ /**
+ * Defines the default oscillator axis (x, y, z) and cycleDuration (w) of the state, used when in global mode.
+ */
+ get: function () {
+ return this._oscillator;
+ },
+ set: function (value) {
+ this._oscillator = value;
+ this.updateOscillatorData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ ParticleOscillatorState.prototype.setRenderState = function (stage, renderable, animationSubGeometry, animationRegisterCache, camera) {
+ var index = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleOscillatorState.OSCILLATOR_INDEX);
+ if (this._particleOscillatorNode.mode == ParticlePropertiesMode.LOCAL_STATIC)
+ animationSubGeometry.activateVertexBuffer(index, this._particleOscillatorNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ else
+ animationRegisterCache.setVertexConst(index, this._oscillatorData.x, this._oscillatorData.y, this._oscillatorData.z, this._oscillatorData.w);
+ };
+ ParticleOscillatorState.prototype.updateOscillatorData = function () {
+ if (this._particleOscillatorNode.mode == ParticlePropertiesMode.GLOBAL) {
+ if (this._oscillator.w <= 0)
+ throw (new Error("the cycle duration must greater than zero"));
+ if (this._oscillatorData == null)
+ this._oscillatorData = new Vector3D();
+ this._oscillatorData.x = this._oscillator.x;
+ this._oscillatorData.y = this._oscillator.y;
+ this._oscillatorData.z = this._oscillator.z;
+ this._oscillatorData.w = Math.PI * 2 / this._oscillator.w;
+ }
+ };
+ /** @private */
+ ParticleOscillatorState.OSCILLATOR_INDEX = 0;
+ return ParticleOscillatorState;
+})(ParticleStateBase);
+module.exports = ParticleOscillatorState;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/states/particleoscillatorstate.ts"],"names":["ParticleOscillatorState","ParticleOscillatorState.constructor","ParticleOscillatorState.oscillator","ParticleOscillatorState.setRenderState","ParticleOscillatorState.updateOscillatorData"],"mappings":"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","file":"animators/states/ParticleOscillatorState.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\nimport Camera\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Camera\");\n\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport RenderableBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/RenderableBase\");\nimport ContextGLVertexBufferFormat\t\t= require(\"awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat\");\n\nimport ParticleAnimator\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimator\");\nimport AnimationSubGeometry\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/AnimationSubGeometry\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleOscillatorNode\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleOscillatorNode\");\nimport ParticleStateBase\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleStateBase\");\n\n/**\n * ...\n */\nclass ParticleOscillatorState extends ParticleStateBase\n{\n\t/** @private */\n\tpublic static OSCILLATOR_INDEX:number /*uint*/ = 0;\n\n\tprivate _particleOscillatorNode:ParticleOscillatorNode;\n\tprivate _oscillator:Vector3D;\n\tprivate _oscillatorData:Vector3D;\n\n\t/**\n\t * Defines the default oscillator axis (x, y, z) and cycleDuration (w) of the state, used when in global mode.\n\t */\n\tpublic get oscillator():Vector3D\n\t{\n\t\treturn this._oscillator;\n\t}\n\n\tpublic set oscillator(value:Vector3D)\n\t{\n\t\tthis._oscillator = value;\n\n\t\tthis.updateOscillatorData();\n\t}\n\n\tconstructor(animator:ParticleAnimator, particleOscillatorNode:ParticleOscillatorNode)\n\t{\n\t\tsuper(animator, particleOscillatorNode);\n\n\t\tthis._particleOscillatorNode = particleOscillatorNode;\n\t\tthis._oscillator = this._particleOscillatorNode._iOscillator;\n\n\t\tthis.updateOscillatorData();\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)\n\t{\n\t\tvar index:number /*int*/ = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleOscillatorState.OSCILLATOR_INDEX);\n\n\t\tif (this._particleOscillatorNode.mode == ParticlePropertiesMode.LOCAL_STATIC)\n\t\t\tanimationSubGeometry.activateVertexBuffer(index, this._particleOscillatorNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);\n\t\telse\n\t\t\tanimationRegisterCache.setVertexConst(index, this._oscillatorData.x, this._oscillatorData.y, this._oscillatorData.z, this._oscillatorData.w);\n\t}\n\n\tprivate updateOscillatorData()\n\t{\n\t\tif (this._particleOscillatorNode.mode == ParticlePropertiesMode.GLOBAL) {\n\t\t\tif (this._oscillator.w <= 0)\n\t\t\t\tthrow(new Error(\"the cycle duration must greater than zero\"));\n\n\t\t\tif (this._oscillatorData == null)\n\t\t\t\tthis._oscillatorData = new Vector3D();\n\n\t\t\tthis._oscillatorData.x = this._oscillator.x;\n\t\t\tthis._oscillatorData.y = this._oscillator.y;\n\t\t\tthis._oscillatorData.z = this._oscillator.z;\n\t\t\tthis._oscillatorData.w = Math.PI*2/this._oscillator.w;\n\t\t}\n\t}\n}\n\nexport = ParticleOscillatorState;"]}
\ No newline at end of file
diff --git a/lib/animators/states/ParticleOscillatorState.ts b/lib/animators/states/ParticleOscillatorState.ts
new file mode 100644
index 000000000..0ddbd5490
--- /dev/null
+++ b/lib/animators/states/ParticleOscillatorState.ts
@@ -0,0 +1,82 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+
+import ParticleAnimator = require("awayjs-renderergl/lib/animators/ParticleAnimator");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleOscillatorNode = require("awayjs-renderergl/lib/animators/nodes/ParticleOscillatorNode");
+import ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+
+/**
+ * ...
+ */
+class ParticleOscillatorState extends ParticleStateBase
+{
+ /** @private */
+ public static OSCILLATOR_INDEX:number /*uint*/ = 0;
+
+ private _particleOscillatorNode:ParticleOscillatorNode;
+ private _oscillator:Vector3D;
+ private _oscillatorData:Vector3D;
+
+ /**
+ * Defines the default oscillator axis (x, y, z) and cycleDuration (w) of the state, used when in global mode.
+ */
+ public get oscillator():Vector3D
+ {
+ return this._oscillator;
+ }
+
+ public set oscillator(value:Vector3D)
+ {
+ this._oscillator = value;
+
+ this.updateOscillatorData();
+ }
+
+ constructor(animator:ParticleAnimator, particleOscillatorNode:ParticleOscillatorNode)
+ {
+ super(animator, particleOscillatorNode);
+
+ this._particleOscillatorNode = particleOscillatorNode;
+ this._oscillator = this._particleOscillatorNode._iOscillator;
+
+ this.updateOscillatorData();
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)
+ {
+ var index:number /*int*/ = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleOscillatorState.OSCILLATOR_INDEX);
+
+ if (this._particleOscillatorNode.mode == ParticlePropertiesMode.LOCAL_STATIC)
+ animationSubGeometry.activateVertexBuffer(index, this._particleOscillatorNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ else
+ animationRegisterCache.setVertexConst(index, this._oscillatorData.x, this._oscillatorData.y, this._oscillatorData.z, this._oscillatorData.w);
+ }
+
+ private updateOscillatorData()
+ {
+ if (this._particleOscillatorNode.mode == ParticlePropertiesMode.GLOBAL) {
+ if (this._oscillator.w <= 0)
+ throw(new Error("the cycle duration must greater than zero"));
+
+ if (this._oscillatorData == null)
+ this._oscillatorData = new Vector3D();
+
+ this._oscillatorData.x = this._oscillator.x;
+ this._oscillatorData.y = this._oscillator.y;
+ this._oscillatorData.z = this._oscillator.z;
+ this._oscillatorData.w = Math.PI*2/this._oscillator.w;
+ }
+ }
+}
+
+export = ParticleOscillatorState;
\ No newline at end of file
diff --git a/lib/animators/states/ParticlePositionState.js b/lib/animators/states/ParticlePositionState.js
new file mode 100755
index 000000000..009a32b44
--- /dev/null
+++ b/lib/animators/states/ParticlePositionState.js
@@ -0,0 +1,62 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+/**
+ * ...
+ * @author ...
+ */
+var ParticlePositionState = (function (_super) {
+ __extends(ParticlePositionState, _super);
+ function ParticlePositionState(animator, particlePositionNode) {
+ _super.call(this, animator, particlePositionNode);
+ this._particlePositionNode = particlePositionNode;
+ this._position = this._particlePositionNode._iPosition;
+ }
+ Object.defineProperty(ParticlePositionState.prototype, "position", {
+ /**
+ * Defines the position of the particle when in global mode. Defaults to 0,0,0.
+ */
+ get: function () {
+ return this._position;
+ },
+ set: function (value) {
+ this._position = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ *
+ */
+ ParticlePositionState.prototype.getPositions = function () {
+ return this._pDynamicProperties;
+ };
+ ParticlePositionState.prototype.setPositions = function (value) {
+ this._pDynamicProperties = value;
+ this._pDynamicPropertiesDirty = new Object();
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticlePositionState.prototype.setRenderState = function (stage, renderable, animationSubGeometry, animationRegisterCache, camera) {
+ if (this._particlePositionNode.mode == ParticlePropertiesMode.LOCAL_DYNAMIC && !this._pDynamicPropertiesDirty[animationSubGeometry._iUniqueId])
+ this._pUpdateDynamicProperties(animationSubGeometry);
+ var index = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticlePositionState.POSITION_INDEX);
+ if (this._particlePositionNode.mode == ParticlePropertiesMode.GLOBAL)
+ animationRegisterCache.setVertexConst(index, this._position.x, this._position.y, this._position.z);
+ else
+ animationSubGeometry.activateVertexBuffer(index, this._particlePositionNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ };
+ /** @private */
+ ParticlePositionState.POSITION_INDEX = 0;
+ return ParticlePositionState;
+})(ParticleStateBase);
+module.exports = ParticlePositionState;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9zdGF0ZXMvcGFydGljbGVwb3NpdGlvbnN0YXRlLnRzIl0sIm5hbWVzIjpbIlBhcnRpY2xlUG9zaXRpb25TdGF0ZSIsIlBhcnRpY2xlUG9zaXRpb25TdGF0ZS5jb25zdHJ1Y3RvciIsIlBhcnRpY2xlUG9zaXRpb25TdGF0ZS5wb3NpdGlvbiIsIlBhcnRpY2xlUG9zaXRpb25TdGF0ZS5nZXRQb3NpdGlvbnMiLCJQYXJ0aWNsZVBvc2l0aW9uU3RhdGUuc2V0UG9zaXRpb25zIiwiUGFydGljbGVQb3NpdGlvblN0YXRlLnNldFJlbmRlclN0YXRlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFNQSxJQUFPLDJCQUEyQixXQUFZLDZEQUE2RCxDQUFDLENBQUM7QUFJN0csSUFBTyxzQkFBc0IsV0FBYSw2REFBNkQsQ0FBQyxDQUFDO0FBRXpHLElBQU8saUJBQWlCLFdBQWMsMERBQTBELENBQUMsQ0FBQztBQUVsRyxBQUlBOzs7R0FERztJQUNHLHFCQUFxQjtJQUFTQSxVQUE5QkEscUJBQXFCQSxVQUEwQkE7SUFvQ3BEQSxTQXBDS0EscUJBQXFCQSxDQW9DZEEsUUFBeUJBLEVBQUVBLG9CQUF5Q0E7UUFFL0VDLGtCQUFNQSxRQUFRQSxFQUFFQSxvQkFBb0JBLENBQUNBLENBQUNBO1FBRXRDQSxJQUFJQSxDQUFDQSxxQkFBcUJBLEdBQUdBLG9CQUFvQkEsQ0FBQ0E7UUFDbERBLElBQUlBLENBQUNBLFNBQVNBLEdBQUdBLElBQUlBLENBQUNBLHFCQUFxQkEsQ0FBQ0EsVUFBVUEsQ0FBQ0E7SUFDeERBLENBQUNBO0lBL0JERCxzQkFBV0EsMkNBQVFBO1FBSG5CQTs7V0FFR0E7YUFDSEE7WUFFQ0UsTUFBTUEsQ0FBQ0EsSUFBSUEsQ0FBQ0EsU0FBU0EsQ0FBQ0E7UUFDdkJBLENBQUNBO2FBRURGLFVBQW9CQSxLQUFjQTtZQUVqQ0UsSUFBSUEsQ0FBQ0EsU0FBU0EsR0FBR0EsS0FBS0EsQ0FBQ0E7UUFDeEJBLENBQUNBOzs7T0FMQUY7SUFPREE7O09BRUdBO0lBQ0lBLDRDQUFZQSxHQUFuQkE7UUFFQ0csTUFBTUEsQ0FBQ0EsSUFBSUEsQ0FBQ0EsbUJBQW1CQSxDQUFDQTtJQUNqQ0EsQ0FBQ0E7SUFFTUgsNENBQVlBLEdBQW5CQSxVQUFvQkEsS0FBcUJBO1FBRXhDSSxJQUFJQSxDQUFDQSxtQkFBbUJBLEdBQUdBLEtBQUtBLENBQUNBO1FBRWpDQSxJQUFJQSxDQUFDQSx3QkFBd0JBLEdBQUdBLElBQUlBLE1BQU1BLEVBQUVBLENBQUNBO0lBQzlDQSxDQUFDQTtJQVVESjs7T0FFR0E7SUFDSUEsOENBQWNBLEdBQXJCQSxVQUFzQkEsS0FBV0EsRUFBRUEsVUFBeUJBLEVBQUVBLG9CQUF5Q0EsRUFBRUEsc0JBQTZDQSxFQUFFQSxNQUFhQTtRQUVwS0ssRUFBRUEsQ0FBQ0EsQ0FBQ0EsSUFBSUEsQ0FBQ0EscUJBQXFCQSxDQUFDQSxJQUFJQSxJQUFJQSxzQkFBc0JBLENBQUNBLGFBQWFBLElBQUlBLENBQUNBLElBQUlBLENBQUNBLHdCQUF3QkEsQ0FBQ0Esb0JBQW9CQSxDQUFDQSxVQUFVQSxDQUFDQSxDQUFDQTtZQUM5SUEsSUFBSUEsQ0FBQ0EseUJBQXlCQSxDQUFDQSxvQkFBb0JBLENBQUNBLENBQUNBO1FBRXREQSxJQUFJQSxLQUFLQSxHQUFrQkEsc0JBQXNCQSxDQUFDQSxnQkFBZ0JBLENBQUNBLElBQUlBLENBQUNBLGVBQWVBLEVBQUVBLHFCQUFxQkEsQ0FBQ0EsY0FBY0EsQ0FBQ0EsQ0FBQ0E7UUFFL0hBLEVBQUVBLENBQUNBLENBQUNBLElBQUlBLENBQUNBLHFCQUFxQkEsQ0FBQ0EsSUFBSUEsSUFBSUEsc0JBQXNCQSxDQUFDQSxNQUFNQSxDQUFDQTtZQUNwRUEsc0JBQXNCQSxDQUFDQSxjQUFjQSxDQUFDQSxLQUFLQSxFQUFFQSxJQUFJQSxDQUFDQSxTQUFTQSxDQUFDQSxDQUFDQSxFQUFFQSxJQUFJQSxDQUFDQSxTQUFTQSxDQUFDQSxDQUFDQSxFQUFFQSxJQUFJQSxDQUFDQSxTQUFTQSxDQUFDQSxDQUFDQSxDQUFDQSxDQUFDQTtRQUNwR0EsSUFBSUE7WUFDSEEsb0JBQW9CQSxDQUFDQSxvQkFBb0JBLENBQUNBLEtBQUtBLEVBQUVBLElBQUlBLENBQUNBLHFCQUFxQkEsQ0FBQ0EsWUFBWUEsRUFBRUEsS0FBS0EsRUFBRUEsMkJBQTJCQSxDQUFDQSxPQUFPQSxDQUFDQSxDQUFDQTtJQUN4SUEsQ0FBQ0E7SUF4RERMLGVBQWVBO0lBQ0RBLG9DQUFjQSxHQUFtQkEsQ0FBQ0EsQ0FBQ0E7SUF3RGxEQSw0QkFBQ0E7QUFBREEsQ0EzREEsQUEyRENBLEVBM0RtQyxpQkFBaUIsRUEyRHBEO0FBRUQsQUFBK0IsaUJBQXRCLHFCQUFxQixDQUFDIiwiZmlsZSI6ImFuaW1hdG9ycy9zdGF0ZXMvUGFydGljbGVQb3NpdGlvblN0YXRlLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2JiYXRlbWFuL1dlYnN0b3JtUHJvamVjdHMvYXdheWpzLXJlbmRlcmVyZ2wvIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFZlY3RvcjNEXHRcdFx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvY29yZS9nZW9tL1ZlY3RvcjNEXCIpO1xuaW1wb3J0IENhbWVyYVx0XHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLWNvcmUvbGliL2VudGl0aWVzL0NhbWVyYVwiKTtcblxuaW1wb3J0IEFuaW1hdGlvblJlZ2lzdGVyQ2FjaGVcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvYW5pbWF0b3JzL2RhdGEvQW5pbWF0aW9uUmVnaXN0ZXJDYWNoZVwiKTtcbmltcG9ydCBTdGFnZVx0XHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2NvcmUvYmFzZS9TdGFnZVwiKTtcbmltcG9ydCBSZW5kZXJhYmxlQmFzZVx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvY29yZS9wb29sL1JlbmRlcmFibGVCYXNlXCIpO1xuaW1wb3J0IENvbnRleHRHTFZlcnRleEJ1ZmZlckZvcm1hdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvY29yZS9zdGFnZWdsL0NvbnRleHRHTFZlcnRleEJ1ZmZlckZvcm1hdFwiKTtcblxuaW1wb3J0IFBhcnRpY2xlQW5pbWF0b3JcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXJlbmRlcmVyZ2wvbGliL2FuaW1hdG9ycy9QYXJ0aWNsZUFuaW1hdG9yXCIpO1xuaW1wb3J0IEFuaW1hdGlvblN1Ykdlb21ldHJ5XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL2RhdGEvQW5pbWF0aW9uU3ViR2VvbWV0cnlcIik7XG5pbXBvcnQgUGFydGljbGVQcm9wZXJ0aWVzTW9kZVx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvZGF0YS9QYXJ0aWNsZVByb3BlcnRpZXNNb2RlXCIpO1xuaW1wb3J0IFBhcnRpY2xlUG9zaXRpb25Ob2RlXHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL25vZGVzL1BhcnRpY2xlUG9zaXRpb25Ob2RlXCIpO1xuaW1wb3J0IFBhcnRpY2xlU3RhdGVCYXNlXHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL3N0YXRlcy9QYXJ0aWNsZVN0YXRlQmFzZVwiKTtcblxuLyoqXG4gKiAuLi5cbiAqIEBhdXRob3IgLi4uXG4gKi9cbmNsYXNzIFBhcnRpY2xlUG9zaXRpb25TdGF0ZSBleHRlbmRzIFBhcnRpY2xlU3RhdGVCYXNlXG57XG5cdC8qKiBAcHJpdmF0ZSAqL1xuXHRwdWJsaWMgc3RhdGljIFBPU0lUSU9OX0lOREVYOm51bWJlciAvKnVpbnQqLyA9IDA7XG5cblx0cHJpdmF0ZSBfcGFydGljbGVQb3NpdGlvbk5vZGU6UGFydGljbGVQb3NpdGlvbk5vZGU7XG5cdHByaXZhdGUgX3Bvc2l0aW9uOlZlY3RvcjNEO1xuXG5cdC8qKlxuXHQgKiBEZWZpbmVzIHRoZSBwb3NpdGlvbiBvZiB0aGUgcGFydGljbGUgd2hlbiBpbiBnbG9iYWwgbW9kZS4gRGVmYXVsdHMgdG8gMCwwLDAuXG5cdCAqL1xuXHRwdWJsaWMgZ2V0IHBvc2l0aW9uKCk6VmVjdG9yM0Rcblx0e1xuXHRcdHJldHVybiB0aGlzLl9wb3NpdGlvbjtcblx0fVxuXG5cdHB1YmxpYyBzZXQgcG9zaXRpb24odmFsdWU6VmVjdG9yM0QpXG5cdHtcblx0XHR0aGlzLl9wb3NpdGlvbiA9IHZhbHVlO1xuXHR9XG5cblx0LyoqXG5cdCAqXG5cdCAqL1xuXHRwdWJsaWMgZ2V0UG9zaXRpb25zKCk6QXJyYXk8VmVjdG9yM0Q+XG5cdHtcblx0XHRyZXR1cm4gdGhpcy5fcER5bmFtaWNQcm9wZXJ0aWVzO1xuXHR9XG5cblx0cHVibGljIHNldFBvc2l0aW9ucyh2YWx1ZTpBcnJheTxWZWN0b3IzRD4pXG5cdHtcblx0XHR0aGlzLl9wRHluYW1pY1Byb3BlcnRpZXMgPSB2YWx1ZTtcblxuXHRcdHRoaXMuX3BEeW5hbWljUHJvcGVydGllc0RpcnR5ID0gbmV3IE9iamVjdCgpO1xuXHR9XG5cblx0Y29uc3RydWN0b3IoYW5pbWF0b3I6UGFydGljbGVBbmltYXRvciwgcGFydGljbGVQb3NpdGlvbk5vZGU6UGFydGljbGVQb3NpdGlvbk5vZGUpXG5cdHtcblx0XHRzdXBlcihhbmltYXRvciwgcGFydGljbGVQb3NpdGlvbk5vZGUpO1xuXG5cdFx0dGhpcy5fcGFydGljbGVQb3NpdGlvbk5vZGUgPSBwYXJ0aWNsZVBvc2l0aW9uTm9kZTtcblx0XHR0aGlzLl9wb3NpdGlvbiA9IHRoaXMuX3BhcnRpY2xlUG9zaXRpb25Ob2RlLl9pUG9zaXRpb247XG5cdH1cblxuXHQvKipcblx0ICogQGluaGVyaXREb2Ncblx0ICovXG5cdHB1YmxpYyBzZXRSZW5kZXJTdGF0ZShzdGFnZTpTdGFnZSwgcmVuZGVyYWJsZTpSZW5kZXJhYmxlQmFzZSwgYW5pbWF0aW9uU3ViR2VvbWV0cnk6QW5pbWF0aW9uU3ViR2VvbWV0cnksIGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGU6QW5pbWF0aW9uUmVnaXN0ZXJDYWNoZSwgY2FtZXJhOkNhbWVyYSlcblx0e1xuXHRcdGlmICh0aGlzLl9wYXJ0aWNsZVBvc2l0aW9uTm9kZS5tb2RlID09IFBhcnRpY2xlUHJvcGVydGllc01vZGUuTE9DQUxfRFlOQU1JQyAmJiAhdGhpcy5fcER5bmFtaWNQcm9wZXJ0aWVzRGlydHlbYW5pbWF0aW9uU3ViR2VvbWV0cnkuX2lVbmlxdWVJZF0pXG5cdFx0XHR0aGlzLl9wVXBkYXRlRHluYW1pY1Byb3BlcnRpZXMoYW5pbWF0aW9uU3ViR2VvbWV0cnkpO1xuXG5cdFx0dmFyIGluZGV4Om51bWJlciAvKmludCovID0gYW5pbWF0aW9uUmVnaXN0ZXJDYWNoZS5nZXRSZWdpc3RlckluZGV4KHRoaXMuX3BBbmltYXRpb25Ob2RlLCBQYXJ0aWNsZVBvc2l0aW9uU3RhdGUuUE9TSVRJT05fSU5ERVgpO1xuXG5cdFx0aWYgKHRoaXMuX3BhcnRpY2xlUG9zaXRpb25Ob2RlLm1vZGUgPT0gUGFydGljbGVQcm9wZXJ0aWVzTW9kZS5HTE9CQUwpXG5cdFx0XHRhbmltYXRpb25SZWdpc3RlckNhY2hlLnNldFZlcnRleENvbnN0KGluZGV4LCB0aGlzLl9wb3NpdGlvbi54LCB0aGlzLl9wb3NpdGlvbi55LCB0aGlzLl9wb3NpdGlvbi56KTtcblx0XHRlbHNlXG5cdFx0XHRhbmltYXRpb25TdWJHZW9tZXRyeS5hY3RpdmF0ZVZlcnRleEJ1ZmZlcihpbmRleCwgdGhpcy5fcGFydGljbGVQb3NpdGlvbk5vZGUuX2lEYXRhT2Zmc2V0LCBzdGFnZSwgQ29udGV4dEdMVmVydGV4QnVmZmVyRm9ybWF0LkZMT0FUXzMpO1xuXHR9XG59XG5cbmV4cG9ydCA9IFBhcnRpY2xlUG9zaXRpb25TdGF0ZTsiXX0=
\ No newline at end of file
diff --git a/lib/animators/states/ParticlePositionState.ts b/lib/animators/states/ParticlePositionState.ts
new file mode 100644
index 000000000..885418c9f
--- /dev/null
+++ b/lib/animators/states/ParticlePositionState.ts
@@ -0,0 +1,80 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+
+import ParticleAnimator = require("awayjs-renderergl/lib/animators/ParticleAnimator");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticlePositionNode = require("awayjs-renderergl/lib/animators/nodes/ParticlePositionNode");
+import ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+
+/**
+ * ...
+ * @author ...
+ */
+class ParticlePositionState extends ParticleStateBase
+{
+ /** @private */
+ public static POSITION_INDEX:number /*uint*/ = 0;
+
+ private _particlePositionNode:ParticlePositionNode;
+ private _position:Vector3D;
+
+ /**
+ * Defines the position of the particle when in global mode. Defaults to 0,0,0.
+ */
+ public get position():Vector3D
+ {
+ return this._position;
+ }
+
+ public set position(value:Vector3D)
+ {
+ this._position = value;
+ }
+
+ /**
+ *
+ */
+ public getPositions():Array
+ {
+ return this._pDynamicProperties;
+ }
+
+ public setPositions(value:Array)
+ {
+ this._pDynamicProperties = value;
+
+ this._pDynamicPropertiesDirty = new Object();
+ }
+
+ constructor(animator:ParticleAnimator, particlePositionNode:ParticlePositionNode)
+ {
+ super(animator, particlePositionNode);
+
+ this._particlePositionNode = particlePositionNode;
+ this._position = this._particlePositionNode._iPosition;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)
+ {
+ if (this._particlePositionNode.mode == ParticlePropertiesMode.LOCAL_DYNAMIC && !this._pDynamicPropertiesDirty[animationSubGeometry._iUniqueId])
+ this._pUpdateDynamicProperties(animationSubGeometry);
+
+ var index:number /*int*/ = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticlePositionState.POSITION_INDEX);
+
+ if (this._particlePositionNode.mode == ParticlePropertiesMode.GLOBAL)
+ animationRegisterCache.setVertexConst(index, this._position.x, this._position.y, this._position.z);
+ else
+ animationSubGeometry.activateVertexBuffer(index, this._particlePositionNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ }
+}
+
+export = ParticlePositionState;
\ No newline at end of file
diff --git a/lib/animators/states/ParticleRotateToHeadingState.js b/lib/animators/states/ParticleRotateToHeadingState.js
new file mode 100755
index 000000000..013d40eb3
--- /dev/null
+++ b/lib/animators/states/ParticleRotateToHeadingState.js
@@ -0,0 +1,31 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Matrix3D = require("awayjs-core/lib/core/geom/Matrix3D");
+var ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+/**
+ * ...
+ */
+var ParticleRotateToHeadingState = (function (_super) {
+ __extends(ParticleRotateToHeadingState, _super);
+ function ParticleRotateToHeadingState(animator, particleNode) {
+ _super.call(this, animator, particleNode);
+ this._matrix = new Matrix3D();
+ }
+ ParticleRotateToHeadingState.prototype.setRenderState = function (stage, renderable, animationSubGeometry, animationRegisterCache, camera) {
+ if (animationRegisterCache.hasBillboard) {
+ this._matrix.copyFrom(renderable.sourceEntity.sceneTransform);
+ this._matrix.append(camera.inverseSceneTransform);
+ animationRegisterCache.setVertexConstFromMatrix(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleRotateToHeadingState.MATRIX_INDEX), this._matrix);
+ }
+ };
+ /** @private */
+ ParticleRotateToHeadingState.MATRIX_INDEX = 0;
+ return ParticleRotateToHeadingState;
+})(ParticleStateBase);
+module.exports = ParticleRotateToHeadingState;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9zdGF0ZXMvcGFydGljbGVyb3RhdGV0b2hlYWRpbmdzdGF0ZS50cyJdLCJuYW1lcyI6WyJQYXJ0aWNsZVJvdGF0ZVRvSGVhZGluZ1N0YXRlIiwiUGFydGljbGVSb3RhdGVUb0hlYWRpbmdTdGF0ZS5jb25zdHJ1Y3RvciIsIlBhcnRpY2xlUm90YXRlVG9IZWFkaW5nU3RhdGUuc2V0UmVuZGVyU3RhdGUiXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQU8sUUFBUSxXQUFpQixvQ0FBb0MsQ0FBQyxDQUFDO0FBV3RFLElBQU8saUJBQWlCLFdBQWMsMERBQTBELENBQUMsQ0FBQztBQUVsRyxBQUdBOztHQURHO0lBQ0csNEJBQTRCO0lBQVNBLFVBQXJDQSw0QkFBNEJBLFVBQTBCQTtJQU8zREEsU0FQS0EsNEJBQTRCQSxDQU9yQkEsUUFBeUJBLEVBQUVBLFlBQTZCQTtRQUVuRUMsa0JBQU1BLFFBQVFBLEVBQUVBLFlBQVlBLENBQUNBLENBQUNBO1FBSnZCQSxZQUFPQSxHQUFZQSxJQUFJQSxRQUFRQSxFQUFFQSxDQUFDQTtJQUsxQ0EsQ0FBQ0E7SUFFTUQscURBQWNBLEdBQXJCQSxVQUFzQkEsS0FBV0EsRUFBRUEsVUFBeUJBLEVBQUVBLG9CQUF5Q0EsRUFBRUEsc0JBQTZDQSxFQUFFQSxNQUFhQTtRQUVwS0UsRUFBRUEsQ0FBQ0EsQ0FBQ0Esc0JBQXNCQSxDQUFDQSxZQUFZQSxDQUFDQSxDQUFDQSxDQUFDQTtZQUN6Q0EsSUFBSUEsQ0FBQ0EsT0FBT0EsQ0FBQ0EsUUFBUUEsQ0FBQ0EsVUFBVUEsQ0FBQ0EsWUFBWUEsQ0FBQ0EsY0FBY0EsQ0FBQ0EsQ0FBQ0E7WUFDOURBLElBQUlBLENBQUNBLE9BQU9BLENBQUNBLE1BQU1BLENBQUNBLE1BQU1BLENBQUNBLHFCQUFxQkEsQ0FBQ0EsQ0FBQ0E7WUFDbERBLHNCQUFzQkEsQ0FBQ0Esd0JBQXdCQSxDQUFDQSxzQkFBc0JBLENBQUNBLGdCQUFnQkEsQ0FBQ0EsSUFBSUEsQ0FBQ0EsZUFBZUEsRUFBRUEsNEJBQTRCQSxDQUFDQSxZQUFZQSxDQUFDQSxFQUFFQSxJQUFJQSxDQUFDQSxPQUFPQSxDQUFDQSxDQUFDQTtRQUN6S0EsQ0FBQ0E7SUFDRkEsQ0FBQ0E7SUFqQkRGLGVBQWVBO0lBQ0RBLHlDQUFZQSxHQUFrQkEsQ0FBQ0EsQ0FBQ0E7SUFrQi9DQSxtQ0FBQ0E7QUFBREEsQ0FyQkEsQUFxQkNBLEVBckIwQyxpQkFBaUIsRUFxQjNEO0FBRUQsQUFBc0MsaUJBQTdCLDRCQUE0QixDQUFDIiwiZmlsZSI6ImFuaW1hdG9ycy9zdGF0ZXMvUGFydGljbGVSb3RhdGVUb0hlYWRpbmdTdGF0ZS5qcyIsInNvdXJjZVJvb3QiOiIvVXNlcnMvcm9iYmF0ZW1hbi9XZWJzdG9ybVByb2plY3RzL2F3YXlqcy1yZW5kZXJlcmdsLyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBNYXRyaXgzRFx0XHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLWNvcmUvbGliL2NvcmUvZ2VvbS9NYXRyaXgzRFwiKTtcbmltcG9ydCBDYW1lcmFcdFx0XHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1jb3JlL2xpYi9lbnRpdGllcy9DYW1lcmFcIik7XG5cbmltcG9ydCBBbmltYXRpb25SZWdpc3RlckNhY2hlXHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2FuaW1hdG9ycy9kYXRhL0FuaW1hdGlvblJlZ2lzdGVyQ2FjaGVcIik7XG5pbXBvcnQgU3RhZ2VcdFx0XHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1zdGFnZWdsL2xpYi9jb3JlL2Jhc2UvU3RhZ2VcIik7XG5pbXBvcnQgUmVuZGVyYWJsZUJhc2VcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2NvcmUvcG9vbC9SZW5kZXJhYmxlQmFzZVwiKTtcblxuaW1wb3J0IFBhcnRpY2xlQW5pbWF0b3JcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXJlbmRlcmVyZ2wvbGliL2FuaW1hdG9ycy9QYXJ0aWNsZUFuaW1hdG9yXCIpO1xuaW1wb3J0IEFuaW1hdGlvblN1Ykdlb21ldHJ5XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL2RhdGEvQW5pbWF0aW9uU3ViR2VvbWV0cnlcIik7XG5pbXBvcnQgUGFydGljbGVOb2RlQmFzZVx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL25vZGVzL1BhcnRpY2xlTm9kZUJhc2VcIik7XG5pbXBvcnQgUGFydGljbGVSb3RhdGVUb0hlYWRpbmdOb2RlXHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvbm9kZXMvUGFydGljbGVSb3RhdGVUb0hlYWRpbmdOb2RlXCIpO1xuaW1wb3J0IFBhcnRpY2xlU3RhdGVCYXNlXHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL3N0YXRlcy9QYXJ0aWNsZVN0YXRlQmFzZVwiKTtcblxuLyoqXG4gKiAuLi5cbiAqL1xuY2xhc3MgUGFydGljbGVSb3RhdGVUb0hlYWRpbmdTdGF0ZSBleHRlbmRzIFBhcnRpY2xlU3RhdGVCYXNlXG57XG5cdC8qKiBAcHJpdmF0ZSAqL1xuXHRwdWJsaWMgc3RhdGljIE1BVFJJWF9JTkRFWDpudW1iZXIgLyppbnQqLyA9IDA7XG5cblx0cHJpdmF0ZSBfbWF0cml4Ok1hdHJpeDNEID0gbmV3IE1hdHJpeDNEKCk7XG5cblx0Y29uc3RydWN0b3IoYW5pbWF0b3I6UGFydGljbGVBbmltYXRvciwgcGFydGljbGVOb2RlOlBhcnRpY2xlTm9kZUJhc2UpXG5cdHtcblx0XHRzdXBlcihhbmltYXRvciwgcGFydGljbGVOb2RlKTtcblx0fVxuXG5cdHB1YmxpYyBzZXRSZW5kZXJTdGF0ZShzdGFnZTpTdGFnZSwgcmVuZGVyYWJsZTpSZW5kZXJhYmxlQmFzZSwgYW5pbWF0aW9uU3ViR2VvbWV0cnk6QW5pbWF0aW9uU3ViR2VvbWV0cnksIGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGU6QW5pbWF0aW9uUmVnaXN0ZXJDYWNoZSwgY2FtZXJhOkNhbWVyYSlcblx0e1xuXHRcdGlmIChhbmltYXRpb25SZWdpc3RlckNhY2hlLmhhc0JpbGxib2FyZCkge1xuXHRcdFx0dGhpcy5fbWF0cml4LmNvcHlGcm9tKHJlbmRlcmFibGUuc291cmNlRW50aXR5LnNjZW5lVHJhbnNmb3JtKTtcblx0XHRcdHRoaXMuX21hdHJpeC5hcHBlbmQoY2FtZXJhLmludmVyc2VTY2VuZVRyYW5zZm9ybSk7XG5cdFx0XHRhbmltYXRpb25SZWdpc3RlckNhY2hlLnNldFZlcnRleENvbnN0RnJvbU1hdHJpeChhbmltYXRpb25SZWdpc3RlckNhY2hlLmdldFJlZ2lzdGVySW5kZXgodGhpcy5fcEFuaW1hdGlvbk5vZGUsIFBhcnRpY2xlUm90YXRlVG9IZWFkaW5nU3RhdGUuTUFUUklYX0lOREVYKSwgdGhpcy5fbWF0cml4KTtcblx0XHR9XG5cdH1cblxufVxuXG5leHBvcnQgPSBQYXJ0aWNsZVJvdGF0ZVRvSGVhZGluZ1N0YXRlOyJdfQ==
\ No newline at end of file
diff --git a/lib/animators/states/ParticleRotateToHeadingState.ts b/lib/animators/states/ParticleRotateToHeadingState.ts
new file mode 100644
index 000000000..40939c73b
--- /dev/null
+++ b/lib/animators/states/ParticleRotateToHeadingState.ts
@@ -0,0 +1,40 @@
+import Matrix3D = require("awayjs-core/lib/core/geom/Matrix3D");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+
+import ParticleAnimator = require("awayjs-renderergl/lib/animators/ParticleAnimator");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import ParticleRotateToHeadingNode = require("awayjs-renderergl/lib/animators/nodes/ParticleRotateToHeadingNode");
+import ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+
+/**
+ * ...
+ */
+class ParticleRotateToHeadingState extends ParticleStateBase
+{
+ /** @private */
+ public static MATRIX_INDEX:number /*int*/ = 0;
+
+ private _matrix:Matrix3D = new Matrix3D();
+
+ constructor(animator:ParticleAnimator, particleNode:ParticleNodeBase)
+ {
+ super(animator, particleNode);
+ }
+
+ public setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)
+ {
+ if (animationRegisterCache.hasBillboard) {
+ this._matrix.copyFrom(renderable.sourceEntity.sceneTransform);
+ this._matrix.append(camera.inverseSceneTransform);
+ animationRegisterCache.setVertexConstFromMatrix(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleRotateToHeadingState.MATRIX_INDEX), this._matrix);
+ }
+ }
+
+}
+
+export = ParticleRotateToHeadingState;
\ No newline at end of file
diff --git a/lib/animators/states/ParticleRotateToPositionState.js b/lib/animators/states/ParticleRotateToPositionState.js
new file mode 100755
index 000000000..a8b30378c
--- /dev/null
+++ b/lib/animators/states/ParticleRotateToPositionState.js
@@ -0,0 +1,57 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Matrix3D = require("awayjs-core/lib/core/geom/Matrix3D");
+var ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+/**
+ * ...
+ */
+var ParticleRotateToPositionState = (function (_super) {
+ __extends(ParticleRotateToPositionState, _super);
+ function ParticleRotateToPositionState(animator, particleRotateToPositionNode) {
+ _super.call(this, animator, particleRotateToPositionNode);
+ this._matrix = new Matrix3D();
+ this._particleRotateToPositionNode = particleRotateToPositionNode;
+ this._position = this._particleRotateToPositionNode._iPosition;
+ }
+ Object.defineProperty(ParticleRotateToPositionState.prototype, "position", {
+ /**
+ * Defines the position of the point the particle will rotate to face when in global mode. Defaults to 0,0,0.
+ */
+ get: function () {
+ return this._position;
+ },
+ set: function (value) {
+ this._position = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ ParticleRotateToPositionState.prototype.setRenderState = function (stage, renderable, animationSubGeometry, animationRegisterCache, camera) {
+ var index = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleRotateToPositionState.POSITION_INDEX);
+ if (animationRegisterCache.hasBillboard) {
+ this._matrix.copyFrom(renderable.sourceEntity.sceneTransform);
+ this._matrix.append(camera.inverseSceneTransform);
+ animationRegisterCache.setVertexConstFromMatrix(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleRotateToPositionState.MATRIX_INDEX), this._matrix);
+ }
+ if (this._particleRotateToPositionNode.mode == ParticlePropertiesMode.GLOBAL) {
+ this._offset = renderable.sourceEntity.inverseSceneTransform.transformVector(this._position);
+ animationRegisterCache.setVertexConst(index, this._offset.x, this._offset.y, this._offset.z);
+ }
+ else
+ animationSubGeometry.activateVertexBuffer(index, this._particleRotateToPositionNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ };
+ /** @private */
+ ParticleRotateToPositionState.MATRIX_INDEX = 0;
+ /** @private */
+ ParticleRotateToPositionState.POSITION_INDEX = 1;
+ return ParticleRotateToPositionState;
+})(ParticleStateBase);
+module.exports = ParticleRotateToPositionState;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9zdGF0ZXMvcGFydGljbGVyb3RhdGV0b3Bvc2l0aW9uc3RhdGUudHMiXSwibmFtZXMiOlsiUGFydGljbGVSb3RhdGVUb1Bvc2l0aW9uU3RhdGUiLCJQYXJ0aWNsZVJvdGF0ZVRvUG9zaXRpb25TdGF0ZS5jb25zdHJ1Y3RvciIsIlBhcnRpY2xlUm90YXRlVG9Qb3NpdGlvblN0YXRlLnBvc2l0aW9uIiwiUGFydGljbGVSb3RhdGVUb1Bvc2l0aW9uU3RhdGUuc2V0UmVuZGVyU3RhdGUiXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQU8sUUFBUSxXQUFpQixvQ0FBb0MsQ0FBQyxDQUFDO0FBT3RFLElBQU8sMkJBQTJCLFdBQVksNkRBQTZELENBQUMsQ0FBQztBQUk3RyxJQUFPLHNCQUFzQixXQUFhLDZEQUE2RCxDQUFDLENBQUM7QUFFekcsSUFBTyxpQkFBaUIsV0FBYywwREFBMEQsQ0FBQyxDQUFDO0FBRWxHLEFBR0E7O0dBREc7SUFDRyw2QkFBNkI7SUFBU0EsVUFBdENBLDZCQUE2QkEsVUFBMEJBO0lBeUI1REEsU0F6QktBLDZCQUE2QkEsQ0F5QnRCQSxRQUF5QkEsRUFBRUEsNEJBQXlEQTtRQUUvRkMsa0JBQU1BLFFBQVFBLEVBQUVBLDRCQUE0QkEsQ0FBQ0EsQ0FBQ0E7UUFsQnZDQSxZQUFPQSxHQUFZQSxJQUFJQSxRQUFRQSxFQUFFQSxDQUFDQTtRQW9CekNBLElBQUlBLENBQUNBLDZCQUE2QkEsR0FBR0EsNEJBQTRCQSxDQUFDQTtRQUNsRUEsSUFBSUEsQ0FBQ0EsU0FBU0EsR0FBR0EsSUFBSUEsQ0FBQ0EsNkJBQTZCQSxDQUFDQSxVQUFVQSxDQUFDQTtJQUNoRUEsQ0FBQ0E7SUFoQkRELHNCQUFXQSxtREFBUUE7UUFIbkJBOztXQUVHQTthQUNIQTtZQUVDRSxNQUFNQSxDQUFDQSxJQUFJQSxDQUFDQSxTQUFTQSxDQUFDQTtRQUN2QkEsQ0FBQ0E7YUFFREYsVUFBb0JBLEtBQWNBO1lBRWpDRSxJQUFJQSxDQUFDQSxTQUFTQSxHQUFHQSxLQUFLQSxDQUFDQTtRQUN4QkEsQ0FBQ0E7OztPQUxBRjtJQWVNQSxzREFBY0EsR0FBckJBLFVBQXNCQSxLQUFXQSxFQUFFQSxVQUF5QkEsRUFBRUEsb0JBQXlDQSxFQUFFQSxzQkFBNkNBLEVBQUVBLE1BQWFBO1FBRXBLRyxJQUFJQSxLQUFLQSxHQUFrQkEsc0JBQXNCQSxDQUFDQSxnQkFBZ0JBLENBQUNBLElBQUlBLENBQUNBLGVBQWVBLEVBQUVBLDZCQUE2QkEsQ0FBQ0EsY0FBY0EsQ0FBQ0EsQ0FBQ0E7UUFFdklBLEVBQUVBLENBQUNBLENBQUNBLHNCQUFzQkEsQ0FBQ0EsWUFBWUEsQ0FBQ0EsQ0FBQ0EsQ0FBQ0E7WUFDekNBLElBQUlBLENBQUNBLE9BQU9BLENBQUNBLFFBQVFBLENBQUNBLFVBQVVBLENBQUNBLFlBQVlBLENBQUNBLGNBQWNBLENBQUNBLENBQUNBO1lBQzlEQSxJQUFJQSxDQUFDQSxPQUFPQSxDQUFDQSxNQUFNQSxDQUFDQSxNQUFNQSxDQUFDQSxxQkFBcUJBLENBQUNBLENBQUNBO1lBQ2xEQSxzQkFBc0JBLENBQUNBLHdCQUF3QkEsQ0FBQ0Esc0JBQXNCQSxDQUFDQSxnQkFBZ0JBLENBQUNBLElBQUlBLENBQUNBLGVBQWVBLEVBQUVBLDZCQUE2QkEsQ0FBQ0EsWUFBWUEsQ0FBQ0EsRUFBRUEsSUFBSUEsQ0FBQ0EsT0FBT0EsQ0FBQ0EsQ0FBQ0E7UUFDMUtBLENBQUNBO1FBRURBLEVBQUVBLENBQUNBLENBQUNBLElBQUlBLENBQUNBLDZCQUE2QkEsQ0FBQ0EsSUFBSUEsSUFBSUEsc0JBQXNCQSxDQUFDQSxNQUFNQSxDQUFDQSxDQUFDQSxDQUFDQTtZQUM5RUEsSUFBSUEsQ0FBQ0EsT0FBT0EsR0FBR0EsVUFBVUEsQ0FBQ0EsWUFBWUEsQ0FBQ0EscUJBQXFCQSxDQUFDQSxlQUFlQSxDQUFDQSxJQUFJQSxDQUFDQSxTQUFTQSxDQUFDQSxDQUFDQTtZQUM3RkEsc0JBQXNCQSxDQUFDQSxjQUFjQSxDQUFDQSxLQUFLQSxFQUFFQSxJQUFJQSxDQUFDQSxPQUFPQSxDQUFDQSxDQUFDQSxFQUFFQSxJQUFJQSxDQUFDQSxPQUFPQSxDQUFDQSxDQUFDQSxFQUFFQSxJQUFJQSxDQUFDQSxPQUFPQSxDQUFDQSxDQUFDQSxDQUFDQSxDQUFDQTtRQUM5RkEsQ0FBQ0E7UUFBQ0EsSUFBSUE7WUFDTEEsb0JBQW9CQSxDQUFDQSxvQkFBb0JBLENBQUNBLEtBQUtBLEVBQUVBLElBQUlBLENBQUNBLDZCQUE2QkEsQ0FBQ0EsWUFBWUEsRUFBRUEsS0FBS0EsRUFBRUEsMkJBQTJCQSxDQUFDQSxPQUFPQSxDQUFDQSxDQUFDQTtJQUVoSkEsQ0FBQ0E7SUEvQ0RILGVBQWVBO0lBQ0RBLDBDQUFZQSxHQUFrQkEsQ0FBQ0EsQ0FBQ0E7SUFDOUNBLGVBQWVBO0lBQ0RBLDRDQUFjQSxHQUFrQkEsQ0FBQ0EsQ0FBQ0E7SUE4Q2pEQSxvQ0FBQ0E7QUFBREEsQ0FuREEsQUFtRENBLEVBbkQyQyxpQkFBaUIsRUFtRDVEO0FBRUQsQUFBdUMsaUJBQTlCLDZCQUE2QixDQUFDIiwiZmlsZSI6ImFuaW1hdG9ycy9zdGF0ZXMvUGFydGljbGVSb3RhdGVUb1Bvc2l0aW9uU3RhdGUuanMiLCJzb3VyY2VSb290IjoiL1VzZXJzL3JvYmJhdGVtYW4vV2Vic3Rvcm1Qcm9qZWN0cy9hd2F5anMtcmVuZGVyZXJnbC8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgTWF0cml4M0RcdFx0XHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1jb3JlL2xpYi9jb3JlL2dlb20vTWF0cml4M0RcIik7XG5pbXBvcnQgVmVjdG9yM0RcdFx0XHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1jb3JlL2xpYi9jb3JlL2dlb20vVmVjdG9yM0RcIik7XG5pbXBvcnQgQ2FtZXJhXHRcdFx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvZW50aXRpZXMvQ2FtZXJhXCIpO1xuXG5pbXBvcnQgQW5pbWF0aW9uUmVnaXN0ZXJDYWNoZVx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1zdGFnZWdsL2xpYi9hbmltYXRvcnMvZGF0YS9BbmltYXRpb25SZWdpc3RlckNhY2hlXCIpO1xuaW1wb3J0IFN0YWdlXHRcdFx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvY29yZS9iYXNlL1N0YWdlXCIpO1xuaW1wb3J0IFJlbmRlcmFibGVCYXNlXHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1zdGFnZWdsL2xpYi9jb3JlL3Bvb2wvUmVuZGVyYWJsZUJhc2VcIik7XG5pbXBvcnQgQ29udGV4dEdMVmVydGV4QnVmZmVyRm9ybWF0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1zdGFnZWdsL2xpYi9jb3JlL3N0YWdlZ2wvQ29udGV4dEdMVmVydGV4QnVmZmVyRm9ybWF0XCIpO1xuXG5pbXBvcnQgUGFydGljbGVBbmltYXRvclx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL1BhcnRpY2xlQW5pbWF0b3JcIik7XG5pbXBvcnQgQW5pbWF0aW9uU3ViR2VvbWV0cnlcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvZGF0YS9BbmltYXRpb25TdWJHZW9tZXRyeVwiKTtcbmltcG9ydCBQYXJ0aWNsZVByb3BlcnRpZXNNb2RlXHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXJlbmRlcmVyZ2wvbGliL2FuaW1hdG9ycy9kYXRhL1BhcnRpY2xlUHJvcGVydGllc01vZGVcIik7XG5pbXBvcnQgUGFydGljbGVSb3RhdGVUb1Bvc2l0aW9uTm9kZVx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL25vZGVzL1BhcnRpY2xlUm90YXRlVG9Qb3NpdGlvbk5vZGVcIik7XG5pbXBvcnQgUGFydGljbGVTdGF0ZUJhc2VcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvc3RhdGVzL1BhcnRpY2xlU3RhdGVCYXNlXCIpO1xuXG4vKipcbiAqIC4uLlxuICovXG5jbGFzcyBQYXJ0aWNsZVJvdGF0ZVRvUG9zaXRpb25TdGF0ZSBleHRlbmRzIFBhcnRpY2xlU3RhdGVCYXNlXG57XG5cdC8qKiBAcHJpdmF0ZSAqL1xuXHRwdWJsaWMgc3RhdGljIE1BVFJJWF9JTkRFWDpudW1iZXIgLyppbnQqLyA9IDA7XG5cdC8qKiBAcHJpdmF0ZSAqL1xuXHRwdWJsaWMgc3RhdGljIFBPU0lUSU9OX0lOREVYOm51bWJlciAvKmludCovID0gMTtcblxuXHRwcml2YXRlIF9wYXJ0aWNsZVJvdGF0ZVRvUG9zaXRpb25Ob2RlOlBhcnRpY2xlUm90YXRlVG9Qb3NpdGlvbk5vZGU7XG5cdHByaXZhdGUgX3Bvc2l0aW9uOlZlY3RvcjNEO1xuXHRwcml2YXRlIF9tYXRyaXg6TWF0cml4M0QgPSBuZXcgTWF0cml4M0QoKTtcblx0cHJpdmF0ZSBfb2Zmc2V0OlZlY3RvcjNEO1xuXG5cdC8qKlxuXHQgKiBEZWZpbmVzIHRoZSBwb3NpdGlvbiBvZiB0aGUgcG9pbnQgdGhlIHBhcnRpY2xlIHdpbGwgcm90YXRlIHRvIGZhY2Ugd2hlbiBpbiBnbG9iYWwgbW9kZS4gRGVmYXVsdHMgdG8gMCwwLDAuXG5cdCAqL1xuXHRwdWJsaWMgZ2V0IHBvc2l0aW9uKCk6VmVjdG9yM0Rcblx0e1xuXHRcdHJldHVybiB0aGlzLl9wb3NpdGlvbjtcblx0fVxuXG5cdHB1YmxpYyBzZXQgcG9zaXRpb24odmFsdWU6VmVjdG9yM0QpXG5cdHtcblx0XHR0aGlzLl9wb3NpdGlvbiA9IHZhbHVlO1xuXHR9XG5cblx0Y29uc3RydWN0b3IoYW5pbWF0b3I6UGFydGljbGVBbmltYXRvciwgcGFydGljbGVSb3RhdGVUb1Bvc2l0aW9uTm9kZTpQYXJ0aWNsZVJvdGF0ZVRvUG9zaXRpb25Ob2RlKVxuXHR7XG5cdFx0c3VwZXIoYW5pbWF0b3IsIHBhcnRpY2xlUm90YXRlVG9Qb3NpdGlvbk5vZGUpO1xuXG5cdFx0dGhpcy5fcGFydGljbGVSb3RhdGVUb1Bvc2l0aW9uTm9kZSA9IHBhcnRpY2xlUm90YXRlVG9Qb3NpdGlvbk5vZGU7XG5cdFx0dGhpcy5fcG9zaXRpb24gPSB0aGlzLl9wYXJ0aWNsZVJvdGF0ZVRvUG9zaXRpb25Ob2RlLl9pUG9zaXRpb247XG5cdH1cblxuXHRwdWJsaWMgc2V0UmVuZGVyU3RhdGUoc3RhZ2U6U3RhZ2UsIHJlbmRlcmFibGU6UmVuZGVyYWJsZUJhc2UsIGFuaW1hdGlvblN1Ykdlb21ldHJ5OkFuaW1hdGlvblN1Ykdlb21ldHJ5LCBhbmltYXRpb25SZWdpc3RlckNhY2hlOkFuaW1hdGlvblJlZ2lzdGVyQ2FjaGUsIGNhbWVyYTpDYW1lcmEpXG5cdHtcblx0XHR2YXIgaW5kZXg6bnVtYmVyIC8qaW50Ki8gPSBhbmltYXRpb25SZWdpc3RlckNhY2hlLmdldFJlZ2lzdGVySW5kZXgodGhpcy5fcEFuaW1hdGlvbk5vZGUsIFBhcnRpY2xlUm90YXRlVG9Qb3NpdGlvblN0YXRlLlBPU0lUSU9OX0lOREVYKTtcblxuXHRcdGlmIChhbmltYXRpb25SZWdpc3RlckNhY2hlLmhhc0JpbGxib2FyZCkge1xuXHRcdFx0dGhpcy5fbWF0cml4LmNvcHlGcm9tKHJlbmRlcmFibGUuc291cmNlRW50aXR5LnNjZW5lVHJhbnNmb3JtKTtcblx0XHRcdHRoaXMuX21hdHJpeC5hcHBlbmQoY2FtZXJhLmludmVyc2VTY2VuZVRyYW5zZm9ybSk7XG5cdFx0XHRhbmltYXRpb25SZWdpc3RlckNhY2hlLnNldFZlcnRleENvbnN0RnJvbU1hdHJpeChhbmltYXRpb25SZWdpc3RlckNhY2hlLmdldFJlZ2lzdGVySW5kZXgodGhpcy5fcEFuaW1hdGlvbk5vZGUsIFBhcnRpY2xlUm90YXRlVG9Qb3NpdGlvblN0YXRlLk1BVFJJWF9JTkRFWCksIHRoaXMuX21hdHJpeCk7XG5cdFx0fVxuXG5cdFx0aWYgKHRoaXMuX3BhcnRpY2xlUm90YXRlVG9Qb3NpdGlvbk5vZGUubW9kZSA9PSBQYXJ0aWNsZVByb3BlcnRpZXNNb2RlLkdMT0JBTCkge1xuXHRcdFx0dGhpcy5fb2Zmc2V0ID0gcmVuZGVyYWJsZS5zb3VyY2VFbnRpdHkuaW52ZXJzZVNjZW5lVHJhbnNmb3JtLnRyYW5zZm9ybVZlY3Rvcih0aGlzLl9wb3NpdGlvbik7XG5cdFx0XHRhbmltYXRpb25SZWdpc3RlckNhY2hlLnNldFZlcnRleENvbnN0KGluZGV4LCB0aGlzLl9vZmZzZXQueCwgdGhpcy5fb2Zmc2V0LnksIHRoaXMuX29mZnNldC56KTtcblx0XHR9IGVsc2Vcblx0XHRcdGFuaW1hdGlvblN1Ykdlb21ldHJ5LmFjdGl2YXRlVmVydGV4QnVmZmVyKGluZGV4LCB0aGlzLl9wYXJ0aWNsZVJvdGF0ZVRvUG9zaXRpb25Ob2RlLl9pRGF0YU9mZnNldCwgc3RhZ2UsIENvbnRleHRHTFZlcnRleEJ1ZmZlckZvcm1hdC5GTE9BVF8zKTtcblxuXHR9XG5cbn1cblxuZXhwb3J0ID0gUGFydGljbGVSb3RhdGVUb1Bvc2l0aW9uU3RhdGU7Il19
\ No newline at end of file
diff --git a/lib/animators/states/ParticleRotateToPositionState.ts b/lib/animators/states/ParticleRotateToPositionState.ts
new file mode 100644
index 000000000..8455db2cd
--- /dev/null
+++ b/lib/animators/states/ParticleRotateToPositionState.ts
@@ -0,0 +1,72 @@
+import Matrix3D = require("awayjs-core/lib/core/geom/Matrix3D");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+
+import ParticleAnimator = require("awayjs-renderergl/lib/animators/ParticleAnimator");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleRotateToPositionNode = require("awayjs-renderergl/lib/animators/nodes/ParticleRotateToPositionNode");
+import ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+
+/**
+ * ...
+ */
+class ParticleRotateToPositionState extends ParticleStateBase
+{
+ /** @private */
+ public static MATRIX_INDEX:number /*int*/ = 0;
+ /** @private */
+ public static POSITION_INDEX:number /*int*/ = 1;
+
+ private _particleRotateToPositionNode:ParticleRotateToPositionNode;
+ private _position:Vector3D;
+ private _matrix:Matrix3D = new Matrix3D();
+ private _offset:Vector3D;
+
+ /**
+ * Defines the position of the point the particle will rotate to face when in global mode. Defaults to 0,0,0.
+ */
+ public get position():Vector3D
+ {
+ return this._position;
+ }
+
+ public set position(value:Vector3D)
+ {
+ this._position = value;
+ }
+
+ constructor(animator:ParticleAnimator, particleRotateToPositionNode:ParticleRotateToPositionNode)
+ {
+ super(animator, particleRotateToPositionNode);
+
+ this._particleRotateToPositionNode = particleRotateToPositionNode;
+ this._position = this._particleRotateToPositionNode._iPosition;
+ }
+
+ public setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)
+ {
+ var index:number /*int*/ = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleRotateToPositionState.POSITION_INDEX);
+
+ if (animationRegisterCache.hasBillboard) {
+ this._matrix.copyFrom(renderable.sourceEntity.sceneTransform);
+ this._matrix.append(camera.inverseSceneTransform);
+ animationRegisterCache.setVertexConstFromMatrix(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleRotateToPositionState.MATRIX_INDEX), this._matrix);
+ }
+
+ if (this._particleRotateToPositionNode.mode == ParticlePropertiesMode.GLOBAL) {
+ this._offset = renderable.sourceEntity.inverseSceneTransform.transformVector(this._position);
+ animationRegisterCache.setVertexConst(index, this._offset.x, this._offset.y, this._offset.z);
+ } else
+ animationSubGeometry.activateVertexBuffer(index, this._particleRotateToPositionNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+
+ }
+
+}
+
+export = ParticleRotateToPositionState;
\ No newline at end of file
diff --git a/lib/animators/states/ParticleRotationalVelocityState.js b/lib/animators/states/ParticleRotationalVelocityState.js
new file mode 100755
index 000000000..7a88bb4c8
--- /dev/null
+++ b/lib/animators/states/ParticleRotationalVelocityState.js
@@ -0,0 +1,77 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+/**
+ * ...
+ */
+var ParticleRotationalVelocityState = (function (_super) {
+ __extends(ParticleRotationalVelocityState, _super);
+ function ParticleRotationalVelocityState(animator, particleRotationNode) {
+ _super.call(this, animator, particleRotationNode);
+ this._particleRotationalVelocityNode = particleRotationNode;
+ this._rotationalVelocity = this._particleRotationalVelocityNode._iRotationalVelocity;
+ this.updateRotationalVelocityData();
+ }
+ Object.defineProperty(ParticleRotationalVelocityState.prototype, "rotationalVelocity", {
+ /**
+ * Defines the default rotationalVelocity of the state, used when in global mode.
+ */
+ get: function () {
+ return this._rotationalVelocity;
+ },
+ set: function (value) {
+ this._rotationalVelocity = value;
+ this.updateRotationalVelocityData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ *
+ */
+ ParticleRotationalVelocityState.prototype.getRotationalVelocities = function () {
+ return this._pDynamicProperties;
+ };
+ ParticleRotationalVelocityState.prototype.setRotationalVelocities = function (value) {
+ this._pDynamicProperties = value;
+ this._pDynamicPropertiesDirty = new Object();
+ };
+ /**
+ * @inheritDoc
+ */
+ ParticleRotationalVelocityState.prototype.setRenderState = function (stage, renderable, animationSubGeometry, animationRegisterCache, camera) {
+ if (this._particleRotationalVelocityNode.mode == ParticlePropertiesMode.LOCAL_DYNAMIC && !this._pDynamicPropertiesDirty[animationSubGeometry._iUniqueId])
+ this._pUpdateDynamicProperties(animationSubGeometry);
+ var index = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleRotationalVelocityState.ROTATIONALVELOCITY_INDEX);
+ if (this._particleRotationalVelocityNode.mode == ParticlePropertiesMode.GLOBAL)
+ animationRegisterCache.setVertexConst(index, this._rotationalVelocityData.x, this._rotationalVelocityData.y, this._rotationalVelocityData.z, this._rotationalVelocityData.w);
+ else
+ animationSubGeometry.activateVertexBuffer(index, this._particleRotationalVelocityNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ };
+ ParticleRotationalVelocityState.prototype.updateRotationalVelocityData = function () {
+ if (this._particleRotationalVelocityNode.mode == ParticlePropertiesMode.GLOBAL) {
+ if (this._rotationalVelocity.w <= 0)
+ throw (new Error("the cycle duration must greater than zero"));
+ var rotation = this._rotationalVelocity.clone();
+ if (rotation.length <= 0)
+ rotation.z = 1; //set the default direction
+ else
+ rotation.normalize();
+ // w is used as angle/2 in agal
+ this._rotationalVelocityData = new Vector3D(rotation.x, rotation.y, rotation.z, Math.PI / rotation.w);
+ }
+ };
+ /** @private */
+ ParticleRotationalVelocityState.ROTATIONALVELOCITY_INDEX = 0;
+ return ParticleRotationalVelocityState;
+})(ParticleStateBase);
+module.exports = ParticleRotationalVelocityState;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/states/particlerotationalvelocitystate.ts"],"names":["ParticleRotationalVelocityState","ParticleRotationalVelocityState.constructor","ParticleRotationalVelocityState.rotationalVelocity","ParticleRotationalVelocityState.getRotationalVelocities","ParticleRotationalVelocityState.setRotationalVelocities","ParticleRotationalVelocityState.setRenderState","ParticleRotationalVelocityState.updateRotationalVelocityData"],"mappings":"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","file":"animators/states/ParticleRotationalVelocityState.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\nimport Camera\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Camera\");\n\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport RenderableBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/RenderableBase\");\nimport ContextGLVertexBufferFormat\t\t= require(\"awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat\");\n\nimport ParticleAnimator\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimator\");\nimport AnimationSubGeometry\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/AnimationSubGeometry\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleRotationalVelocityNode\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleRotationalVelocityNode\");\nimport ParticleStateBase\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleStateBase\");\n\n/**\n * ...\n */\nclass ParticleRotationalVelocityState extends ParticleStateBase\n{\n\t/** @private */\n\tpublic static ROTATIONALVELOCITY_INDEX:number /*uint*/ = 0;\n\n\tprivate _particleRotationalVelocityNode:ParticleRotationalVelocityNode;\n\tprivate _rotationalVelocityData:Vector3D;\n\tprivate _rotationalVelocity:Vector3D;\n\n\t/**\n\t * Defines the default rotationalVelocity of the state, used when in global mode.\n\t */\n\tpublic get rotationalVelocity():Vector3D\n\t{\n\t\treturn this._rotationalVelocity;\n\t}\n\n\tpublic set rotationalVelocity(value:Vector3D)\n\t{\n\t\tthis._rotationalVelocity = value;\n\n\t\tthis.updateRotationalVelocityData();\n\t}\n\n\t/**\n\t *\n\t */\n\tpublic getRotationalVelocities():Array<Vector3D>\n\t{\n\t\treturn this._pDynamicProperties;\n\t}\n\n\tpublic setRotationalVelocities(value:Array<Vector3D>)\n\t{\n\t\tthis._pDynamicProperties = value;\n\n\t\tthis._pDynamicPropertiesDirty = new Object();\n\t}\n\n\tconstructor(animator:ParticleAnimator, particleRotationNode:ParticleRotationalVelocityNode)\n\t{\n\t\tsuper(animator, particleRotationNode);\n\n\t\tthis._particleRotationalVelocityNode = particleRotationNode;\n\t\tthis._rotationalVelocity = this._particleRotationalVelocityNode._iRotationalVelocity;\n\n\t\tthis.updateRotationalVelocityData();\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)\n\t{\n\t\tif (this._particleRotationalVelocityNode.mode == ParticlePropertiesMode.LOCAL_DYNAMIC && !this._pDynamicPropertiesDirty[animationSubGeometry._iUniqueId])\n\t\t\tthis._pUpdateDynamicProperties(animationSubGeometry);\n\n\t\tvar index:number /*int*/ = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleRotationalVelocityState.ROTATIONALVELOCITY_INDEX);\n\n\t\tif (this._particleRotationalVelocityNode.mode == ParticlePropertiesMode.GLOBAL)\n\t\t\tanimationRegisterCache.setVertexConst(index, this._rotationalVelocityData.x, this._rotationalVelocityData.y, this._rotationalVelocityData.z, this._rotationalVelocityData.w);\n\t\telse\n\t\t\tanimationSubGeometry.activateVertexBuffer(index, this._particleRotationalVelocityNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);\n\t}\n\n\tprivate updateRotationalVelocityData()\n\t{\n\t\tif (this._particleRotationalVelocityNode.mode == ParticlePropertiesMode.GLOBAL) {\n\t\t\tif (this._rotationalVelocity.w <= 0)\n\t\t\t\tthrow(new Error(\"the cycle duration must greater than zero\"));\n\t\t\tvar rotation:Vector3D = this._rotationalVelocity.clone();\n\n\t\t\tif (rotation.length <= 0)\n\t\t\t\trotation.z = 1; //set the default direction\n\t\t\telse\n\t\t\t\trotation.normalize();\n\t\t\t// w is used as angle/2 in agal\n\t\t\tthis._rotationalVelocityData = new Vector3D(rotation.x, rotation.y, rotation.z, Math.PI/rotation.w);\n\t\t}\n\t}\n}\n\nexport = ParticleRotationalVelocityState;"]}
\ No newline at end of file
diff --git a/lib/animators/states/ParticleRotationalVelocityState.ts b/lib/animators/states/ParticleRotationalVelocityState.ts
new file mode 100644
index 000000000..90a34fadf
--- /dev/null
+++ b/lib/animators/states/ParticleRotationalVelocityState.ts
@@ -0,0 +1,100 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+
+import ParticleAnimator = require("awayjs-renderergl/lib/animators/ParticleAnimator");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleRotationalVelocityNode = require("awayjs-renderergl/lib/animators/nodes/ParticleRotationalVelocityNode");
+import ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+
+/**
+ * ...
+ */
+class ParticleRotationalVelocityState extends ParticleStateBase
+{
+ /** @private */
+ public static ROTATIONALVELOCITY_INDEX:number /*uint*/ = 0;
+
+ private _particleRotationalVelocityNode:ParticleRotationalVelocityNode;
+ private _rotationalVelocityData:Vector3D;
+ private _rotationalVelocity:Vector3D;
+
+ /**
+ * Defines the default rotationalVelocity of the state, used when in global mode.
+ */
+ public get rotationalVelocity():Vector3D
+ {
+ return this._rotationalVelocity;
+ }
+
+ public set rotationalVelocity(value:Vector3D)
+ {
+ this._rotationalVelocity = value;
+
+ this.updateRotationalVelocityData();
+ }
+
+ /**
+ *
+ */
+ public getRotationalVelocities():Array
+ {
+ return this._pDynamicProperties;
+ }
+
+ public setRotationalVelocities(value:Array)
+ {
+ this._pDynamicProperties = value;
+
+ this._pDynamicPropertiesDirty = new Object();
+ }
+
+ constructor(animator:ParticleAnimator, particleRotationNode:ParticleRotationalVelocityNode)
+ {
+ super(animator, particleRotationNode);
+
+ this._particleRotationalVelocityNode = particleRotationNode;
+ this._rotationalVelocity = this._particleRotationalVelocityNode._iRotationalVelocity;
+
+ this.updateRotationalVelocityData();
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)
+ {
+ if (this._particleRotationalVelocityNode.mode == ParticlePropertiesMode.LOCAL_DYNAMIC && !this._pDynamicPropertiesDirty[animationSubGeometry._iUniqueId])
+ this._pUpdateDynamicProperties(animationSubGeometry);
+
+ var index:number /*int*/ = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleRotationalVelocityState.ROTATIONALVELOCITY_INDEX);
+
+ if (this._particleRotationalVelocityNode.mode == ParticlePropertiesMode.GLOBAL)
+ animationRegisterCache.setVertexConst(index, this._rotationalVelocityData.x, this._rotationalVelocityData.y, this._rotationalVelocityData.z, this._rotationalVelocityData.w);
+ else
+ animationSubGeometry.activateVertexBuffer(index, this._particleRotationalVelocityNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ }
+
+ private updateRotationalVelocityData()
+ {
+ if (this._particleRotationalVelocityNode.mode == ParticlePropertiesMode.GLOBAL) {
+ if (this._rotationalVelocity.w <= 0)
+ throw(new Error("the cycle duration must greater than zero"));
+ var rotation:Vector3D = this._rotationalVelocity.clone();
+
+ if (rotation.length <= 0)
+ rotation.z = 1; //set the default direction
+ else
+ rotation.normalize();
+ // w is used as angle/2 in agal
+ this._rotationalVelocityData = new Vector3D(rotation.x, rotation.y, rotation.z, Math.PI/rotation.w);
+ }
+ }
+}
+
+export = ParticleRotationalVelocityState;
\ No newline at end of file
diff --git a/lib/animators/states/ParticleScaleState.js b/lib/animators/states/ParticleScaleState.js
new file mode 100755
index 000000000..e04312cd2
--- /dev/null
+++ b/lib/animators/states/ParticleScaleState.js
@@ -0,0 +1,115 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+/**
+ * ...
+ */
+var ParticleScaleState = (function (_super) {
+ __extends(ParticleScaleState, _super);
+ function ParticleScaleState(animator, particleScaleNode) {
+ _super.call(this, animator, particleScaleNode);
+ this._particleScaleNode = particleScaleNode;
+ this._usesCycle = this._particleScaleNode._iUsesCycle;
+ this._usesPhase = this._particleScaleNode._iUsesPhase;
+ this._minScale = this._particleScaleNode._iMinScale;
+ this._maxScale = this._particleScaleNode._iMaxScale;
+ this._cycleDuration = this._particleScaleNode._iCycleDuration;
+ this._cyclePhase = this._particleScaleNode._iCyclePhase;
+ this.updateScaleData();
+ }
+ Object.defineProperty(ParticleScaleState.prototype, "minScale", {
+ /**
+ * Defines the end scale of the state, when in global mode. Defaults to 1.
+ */
+ get: function () {
+ return this._minScale;
+ },
+ set: function (value) {
+ this._minScale = value;
+ this.updateScaleData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleScaleState.prototype, "maxScale", {
+ /**
+ * Defines the end scale of the state, when in global mode. Defaults to 1.
+ */
+ get: function () {
+ return this._maxScale;
+ },
+ set: function (value) {
+ this._maxScale = value;
+ this.updateScaleData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleScaleState.prototype, "cycleDuration", {
+ /**
+ * Defines the duration of the animation in seconds, used as a period independent of particle duration when in global mode. Defaults to 1.
+ */
+ get: function () {
+ return this._cycleDuration;
+ },
+ set: function (value) {
+ this._cycleDuration = value;
+ this.updateScaleData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleScaleState.prototype, "cyclePhase", {
+ /**
+ * Defines the phase of the cycle in degrees, used as the starting offset of the cycle when in global mode. Defaults to 0.
+ */
+ get: function () {
+ return this._cyclePhase;
+ },
+ set: function (value) {
+ this._cyclePhase = value;
+ this.updateScaleData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ ParticleScaleState.prototype.setRenderState = function (stage, renderable, animationSubGeometry, animationRegisterCache, camera) {
+ var index = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleScaleState.SCALE_INDEX);
+ if (this._particleScaleNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {
+ if (this._usesCycle) {
+ if (this._usesPhase)
+ animationSubGeometry.activateVertexBuffer(index, this._particleScaleNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ else
+ animationSubGeometry.activateVertexBuffer(index, this._particleScaleNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ }
+ else
+ animationSubGeometry.activateVertexBuffer(index, this._particleScaleNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_2);
+ }
+ else
+ animationRegisterCache.setVertexConst(index, this._scaleData.x, this._scaleData.y, this._scaleData.z, this._scaleData.w);
+ };
+ ParticleScaleState.prototype.updateScaleData = function () {
+ if (this._particleScaleNode.mode == ParticlePropertiesMode.GLOBAL) {
+ if (this._usesCycle) {
+ if (this._cycleDuration <= 0)
+ throw (new Error("the cycle duration must be greater than zero"));
+ this._scaleData = new Vector3D((this._minScale + this._maxScale) / 2, Math.abs(this._minScale - this._maxScale) / 2, Math.PI * 2 / this._cycleDuration, this._cyclePhase * Math.PI / 180);
+ }
+ else
+ this._scaleData = new Vector3D(this._minScale, this._maxScale - this._minScale, 0, 0);
+ }
+ };
+ /** @private */
+ ParticleScaleState.SCALE_INDEX = 0;
+ return ParticleScaleState;
+})(ParticleStateBase);
+module.exports = ParticleScaleState;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/states/particlescalestate.ts"],"names":["ParticleScaleState","ParticleScaleState.constructor","ParticleScaleState.minScale","ParticleScaleState.maxScale","ParticleScaleState.cycleDuration","ParticleScaleState.cyclePhase","ParticleScaleState.setRenderState","ParticleScaleState.updateScaleData"],"mappings":"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","file":"animators/states/ParticleScaleState.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\nimport Camera\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Camera\");\n\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport RenderableBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/RenderableBase\");\nimport ContextGLVertexBufferFormat\t\t= require(\"awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat\");\n\nimport ParticleAnimator\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimator\");\nimport AnimationSubGeometry\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/AnimationSubGeometry\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleScaleNode\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleScaleNode\");\nimport ParticleStateBase\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleStateBase\");\n\n/**\n * ...\n */\nclass ParticleScaleState extends ParticleStateBase\n{\n\t/** @private */\n\tpublic static SCALE_INDEX:number /*uint*/ = 0;\n\n\tprivate _particleScaleNode:ParticleScaleNode;\n\tprivate _usesCycle:boolean;\n\tprivate _usesPhase:boolean;\n\tprivate _minScale:number;\n\tprivate _maxScale:number;\n\tprivate _cycleDuration:number;\n\tprivate _cyclePhase:number;\n\tprivate _scaleData:Vector3D;\n\n\t/**\n\t * Defines the end scale of the state, when in global mode. Defaults to 1.\n\t */\n\tpublic get minScale():number\n\t{\n\t\treturn this._minScale;\n\t}\n\n\tpublic set minScale(value:number)\n\t{\n\t\tthis._minScale = value;\n\n\t\tthis.updateScaleData();\n\t}\n\n\t/**\n\t * Defines the end scale of the state, when in global mode. Defaults to 1.\n\t */\n\tpublic get maxScale():number\n\t{\n\t\treturn this._maxScale;\n\t}\n\n\tpublic set maxScale(value:number)\n\t{\n\t\tthis._maxScale = value;\n\n\t\tthis.updateScaleData();\n\t}\n\n\t/**\n\t * Defines the duration of the animation in seconds, used as a period independent of particle duration when in global mode. Defaults to 1.\n\t */\n\tpublic get cycleDuration():number\n\t{\n\t\treturn this._cycleDuration;\n\t}\n\n\tpublic set cycleDuration(value:number)\n\t{\n\t\tthis._cycleDuration = value;\n\n\t\tthis.updateScaleData();\n\t}\n\n\t/**\n\t * Defines the phase of the cycle in degrees, used as the starting offset of the cycle when in global mode. Defaults to 0.\n\t */\n\tpublic get cyclePhase():number\n\t{\n\t\treturn this._cyclePhase;\n\t}\n\n\tpublic set cyclePhase(value:number)\n\t{\n\t\tthis._cyclePhase = value;\n\n\t\tthis.updateScaleData();\n\t}\n\n\tconstructor(animator:ParticleAnimator, particleScaleNode:ParticleScaleNode)\n\t{\n\t\tsuper(animator, particleScaleNode);\n\n\t\tthis._particleScaleNode = particleScaleNode;\n\t\tthis._usesCycle = this._particleScaleNode._iUsesCycle;\n\t\tthis._usesPhase = this._particleScaleNode._iUsesPhase;\n\t\tthis._minScale = this._particleScaleNode._iMinScale;\n\t\tthis._maxScale = this._particleScaleNode._iMaxScale;\n\t\tthis._cycleDuration = this._particleScaleNode._iCycleDuration;\n\t\tthis._cyclePhase = this._particleScaleNode._iCyclePhase;\n\n\t\tthis.updateScaleData();\n\t}\n\n\tpublic setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)\n\t{\n\t\tvar index:number /*int*/ = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleScaleState.SCALE_INDEX);\n\n\t\tif (this._particleScaleNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {\n\t\t\tif (this._usesCycle) {\n\t\t\t\tif (this._usesPhase)\n\t\t\t\t\tanimationSubGeometry.activateVertexBuffer(index, this._particleScaleNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);\n\t\t\t\telse\n\t\t\t\t\tanimationSubGeometry.activateVertexBuffer(index, this._particleScaleNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);\n\t\t\t} else\n\t\t\t\tanimationSubGeometry.activateVertexBuffer(index, this._particleScaleNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_2);\n\t\t} else\n\t\t\tanimationRegisterCache.setVertexConst(index, this._scaleData.x, this._scaleData.y, this._scaleData.z, this._scaleData.w);\n\t}\n\n\tprivate updateScaleData()\n\t{\n\t\tif (this._particleScaleNode.mode == ParticlePropertiesMode.GLOBAL) {\n\t\t\tif (this._usesCycle) {\n\t\t\t\tif (this._cycleDuration <= 0)\n\t\t\t\t\tthrow(new Error(\"the cycle duration must be greater than zero\"));\n\t\t\t\tthis._scaleData = new Vector3D((this._minScale + this._maxScale)/2, Math.abs(this._minScale - this._maxScale)/2, Math.PI*2/this._cycleDuration, this._cyclePhase*Math.PI/180);\n\t\t\t} else\n\t\t\t\tthis._scaleData = new Vector3D(this._minScale, this._maxScale - this._minScale, 0, 0);\n\t\t}\n\t}\n}\n\nexport = ParticleScaleState;"]}
\ No newline at end of file
diff --git a/lib/animators/states/ParticleScaleState.ts b/lib/animators/states/ParticleScaleState.ts
new file mode 100644
index 000000000..e3e7a8802
--- /dev/null
+++ b/lib/animators/states/ParticleScaleState.ts
@@ -0,0 +1,136 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+
+import ParticleAnimator = require("awayjs-renderergl/lib/animators/ParticleAnimator");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleScaleNode = require("awayjs-renderergl/lib/animators/nodes/ParticleScaleNode");
+import ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+
+/**
+ * ...
+ */
+class ParticleScaleState extends ParticleStateBase
+{
+ /** @private */
+ public static SCALE_INDEX:number /*uint*/ = 0;
+
+ private _particleScaleNode:ParticleScaleNode;
+ private _usesCycle:boolean;
+ private _usesPhase:boolean;
+ private _minScale:number;
+ private _maxScale:number;
+ private _cycleDuration:number;
+ private _cyclePhase:number;
+ private _scaleData:Vector3D;
+
+ /**
+ * Defines the end scale of the state, when in global mode. Defaults to 1.
+ */
+ public get minScale():number
+ {
+ return this._minScale;
+ }
+
+ public set minScale(value:number)
+ {
+ this._minScale = value;
+
+ this.updateScaleData();
+ }
+
+ /**
+ * Defines the end scale of the state, when in global mode. Defaults to 1.
+ */
+ public get maxScale():number
+ {
+ return this._maxScale;
+ }
+
+ public set maxScale(value:number)
+ {
+ this._maxScale = value;
+
+ this.updateScaleData();
+ }
+
+ /**
+ * Defines the duration of the animation in seconds, used as a period independent of particle duration when in global mode. Defaults to 1.
+ */
+ public get cycleDuration():number
+ {
+ return this._cycleDuration;
+ }
+
+ public set cycleDuration(value:number)
+ {
+ this._cycleDuration = value;
+
+ this.updateScaleData();
+ }
+
+ /**
+ * Defines the phase of the cycle in degrees, used as the starting offset of the cycle when in global mode. Defaults to 0.
+ */
+ public get cyclePhase():number
+ {
+ return this._cyclePhase;
+ }
+
+ public set cyclePhase(value:number)
+ {
+ this._cyclePhase = value;
+
+ this.updateScaleData();
+ }
+
+ constructor(animator:ParticleAnimator, particleScaleNode:ParticleScaleNode)
+ {
+ super(animator, particleScaleNode);
+
+ this._particleScaleNode = particleScaleNode;
+ this._usesCycle = this._particleScaleNode._iUsesCycle;
+ this._usesPhase = this._particleScaleNode._iUsesPhase;
+ this._minScale = this._particleScaleNode._iMinScale;
+ this._maxScale = this._particleScaleNode._iMaxScale;
+ this._cycleDuration = this._particleScaleNode._iCycleDuration;
+ this._cyclePhase = this._particleScaleNode._iCyclePhase;
+
+ this.updateScaleData();
+ }
+
+ public setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)
+ {
+ var index:number /*int*/ = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleScaleState.SCALE_INDEX);
+
+ if (this._particleScaleNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {
+ if (this._usesCycle) {
+ if (this._usesPhase)
+ animationSubGeometry.activateVertexBuffer(index, this._particleScaleNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ else
+ animationSubGeometry.activateVertexBuffer(index, this._particleScaleNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ } else
+ animationSubGeometry.activateVertexBuffer(index, this._particleScaleNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_2);
+ } else
+ animationRegisterCache.setVertexConst(index, this._scaleData.x, this._scaleData.y, this._scaleData.z, this._scaleData.w);
+ }
+
+ private updateScaleData()
+ {
+ if (this._particleScaleNode.mode == ParticlePropertiesMode.GLOBAL) {
+ if (this._usesCycle) {
+ if (this._cycleDuration <= 0)
+ throw(new Error("the cycle duration must be greater than zero"));
+ this._scaleData = new Vector3D((this._minScale + this._maxScale)/2, Math.abs(this._minScale - this._maxScale)/2, Math.PI*2/this._cycleDuration, this._cyclePhase*Math.PI/180);
+ } else
+ this._scaleData = new Vector3D(this._minScale, this._maxScale - this._minScale, 0, 0);
+ }
+ }
+}
+
+export = ParticleScaleState;
\ No newline at end of file
diff --git a/lib/animators/states/ParticleSegmentedColorState.js b/lib/animators/states/ParticleSegmentedColorState.js
new file mode 100755
index 000000000..f89addc78
--- /dev/null
+++ b/lib/animators/states/ParticleSegmentedColorState.js
@@ -0,0 +1,153 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+/**
+ *
+ */
+var ParticleSegmentedColorState = (function (_super) {
+ __extends(ParticleSegmentedColorState, _super);
+ function ParticleSegmentedColorState(animator, particleSegmentedColorNode) {
+ _super.call(this, animator, particleSegmentedColorNode);
+ this._usesMultiplier = particleSegmentedColorNode._iUsesMultiplier;
+ this._usesOffset = particleSegmentedColorNode._iUsesOffset;
+ this._startColor = particleSegmentedColorNode._iStartColor;
+ this._endColor = particleSegmentedColorNode._iEndColor;
+ this._segmentPoints = particleSegmentedColorNode._iSegmentPoints;
+ this._numSegmentPoint = particleSegmentedColorNode._iNumSegmentPoint;
+ this.updateColorData();
+ }
+ Object.defineProperty(ParticleSegmentedColorState.prototype, "startColor", {
+ /**
+ * Defines the start color transform of the state, when in global mode.
+ */
+ get: function () {
+ return this._startColor;
+ },
+ set: function (value) {
+ this._startColor = value;
+ this.updateColorData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleSegmentedColorState.prototype, "endColor", {
+ /**
+ * Defines the end color transform of the state, when in global mode.
+ */
+ get: function () {
+ return this._endColor;
+ },
+ set: function (value) {
+ this._endColor = value;
+ this.updateColorData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleSegmentedColorState.prototype, "numSegmentPoint", {
+ /**
+ * Defines the number of segments.
+ */
+ get: function () {
+ return this._numSegmentPoint;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleSegmentedColorState.prototype, "segmentPoints", {
+ /**
+ * Defines the key points of color
+ */
+ get: function () {
+ return this._segmentPoints;
+ },
+ set: function (value) {
+ this._segmentPoints = value;
+ this.updateColorData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleSegmentedColorState.prototype, "usesMultiplier", {
+ get: function () {
+ return this._usesMultiplier;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleSegmentedColorState.prototype, "usesOffset", {
+ get: function () {
+ return this._usesOffset;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ ParticleSegmentedColorState.prototype.setRenderState = function (stage, renderable, animationSubGeometry, animationRegisterCache, camera) {
+ if (animationRegisterCache.needFragmentAnimation) {
+ if (this._numSegmentPoint > 0)
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleSegmentedColorState.TIME_DATA_INDEX), this._timeLifeData[0], this._timeLifeData[1], this._timeLifeData[2], this._timeLifeData[3]);
+ if (this._usesMultiplier)
+ animationRegisterCache.setVertexConstFromArray(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleSegmentedColorState.START_MULTIPLIER_INDEX), this._multiplierData);
+ if (this._usesOffset)
+ animationRegisterCache.setVertexConstFromArray(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleSegmentedColorState.START_OFFSET_INDEX), this._offsetData);
+ }
+ };
+ ParticleSegmentedColorState.prototype.updateColorData = function () {
+ this._timeLifeData = new Array();
+ this._multiplierData = new Array();
+ this._offsetData = new Array();
+ var i /*int*/;
+ for (i = 0; i < this._numSegmentPoint; i++) {
+ if (i == 0)
+ this._timeLifeData.push(this._segmentPoints[i].life);
+ else
+ this._timeLifeData.push(this._segmentPoints[i].life - this._segmentPoints[i - 1].life);
+ }
+ if (this._numSegmentPoint == 0)
+ this._timeLifeData.push(1);
+ else
+ this._timeLifeData.push(1 - this._segmentPoints[i - 1].life);
+ if (this._usesMultiplier) {
+ this._multiplierData.push(this._startColor.redMultiplier, this._startColor.greenMultiplier, this._startColor.blueMultiplier, this._startColor.alphaMultiplier);
+ for (i = 0; i < this._numSegmentPoint; i++) {
+ if (i == 0)
+ this._multiplierData.push((this._segmentPoints[i].color.redMultiplier - this._startColor.redMultiplier) / this._timeLifeData[i], (this._segmentPoints[i].color.greenMultiplier - this._startColor.greenMultiplier) / this._timeLifeData[i], (this._segmentPoints[i].color.blueMultiplier - this._startColor.blueMultiplier) / this._timeLifeData[i], (this._segmentPoints[i].color.alphaMultiplier - this._startColor.alphaMultiplier) / this._timeLifeData[i]);
+ else
+ this._multiplierData.push((this._segmentPoints[i].color.redMultiplier - this._segmentPoints[i - 1].color.redMultiplier) / this._timeLifeData[i], (this._segmentPoints[i].color.greenMultiplier - this._segmentPoints[i - 1].color.greenMultiplier) / this._timeLifeData[i], (this._segmentPoints[i].color.blueMultiplier - this._segmentPoints[i - 1].color.blueMultiplier) / this._timeLifeData[i], (this._segmentPoints[i].color.alphaMultiplier - this._segmentPoints[i - 1].color.alphaMultiplier) / this._timeLifeData[i]);
+ }
+ if (this._numSegmentPoint == 0)
+ this._multiplierData.push(this._endColor.redMultiplier - this._startColor.redMultiplier, this._endColor.greenMultiplier - this._startColor.greenMultiplier, this._endColor.blueMultiplier - this._startColor.blueMultiplier, this._endColor.alphaMultiplier - this._startColor.alphaMultiplier);
+ else
+ this._multiplierData.push((this._endColor.redMultiplier - this._segmentPoints[i - 1].color.redMultiplier) / this._timeLifeData[i], (this._endColor.greenMultiplier - this._segmentPoints[i - 1].color.greenMultiplier) / this._timeLifeData[i], (this._endColor.blueMultiplier - this._segmentPoints[i - 1].color.blueMultiplier) / this._timeLifeData[i], (this._endColor.alphaMultiplier - this._segmentPoints[i - 1].color.alphaMultiplier) / this._timeLifeData[i]);
+ }
+ if (this._usesOffset) {
+ this._offsetData.push(this._startColor.redOffset / 255, this._startColor.greenOffset / 255, this._startColor.blueOffset / 255, this._startColor.alphaOffset / 255);
+ for (i = 0; i < this._numSegmentPoint; i++) {
+ if (i == 0)
+ this._offsetData.push((this._segmentPoints[i].color.redOffset - this._startColor.redOffset) / this._timeLifeData[i] / 255, (this._segmentPoints[i].color.greenOffset - this._startColor.greenOffset) / this._timeLifeData[i] / 255, (this._segmentPoints[i].color.blueOffset - this._startColor.blueOffset) / this._timeLifeData[i] / 255, (this._segmentPoints[i].color.alphaOffset - this._startColor.alphaOffset) / this._timeLifeData[i] / 255);
+ else
+ this._offsetData.push((this._segmentPoints[i].color.redOffset - this._segmentPoints[i - 1].color.redOffset) / this._timeLifeData[i] / 255, (this._segmentPoints[i].color.greenOffset - this._segmentPoints[i - 1].color.greenOffset) / this._timeLifeData[i] / 255, (this._segmentPoints[i].color.blueOffset - this._segmentPoints[i - 1].color.blueOffset) / this._timeLifeData[i] / 255, (this._segmentPoints[i].color.alphaOffset - this._segmentPoints[i - 1].color.alphaOffset) / this._timeLifeData[i] / 255);
+ }
+ if (this._numSegmentPoint == 0)
+ this._offsetData.push((this._endColor.redOffset - this._startColor.redOffset) / 255, (this._endColor.greenOffset - this._startColor.greenOffset) / 255, (this._endColor.blueOffset - this._startColor.blueOffset) / 255, (this._endColor.alphaOffset - this._startColor.alphaOffset) / 255);
+ else
+ this._offsetData.push((this._endColor.redOffset - this._segmentPoints[i - 1].color.redOffset) / this._timeLifeData[i] / 255, (this._endColor.greenOffset - this._segmentPoints[i - 1].color.greenOffset) / this._timeLifeData[i] / 255, (this._endColor.blueOffset - this._segmentPoints[i - 1].color.blueOffset) / this._timeLifeData[i] / 255, (this._endColor.alphaOffset - this._segmentPoints[i - 1].color.alphaOffset) / this._timeLifeData[i] / 255);
+ }
+ //cut off the data
+ this._timeLifeData.length = 4;
+ };
+ /** @private */
+ ParticleSegmentedColorState.START_MULTIPLIER_INDEX = 0;
+ /** @private */
+ ParticleSegmentedColorState.START_OFFSET_INDEX = 1;
+ /** @private */
+ ParticleSegmentedColorState.TIME_DATA_INDEX = 2;
+ return ParticleSegmentedColorState;
+})(ParticleStateBase);
+module.exports = ParticleSegmentedColorState;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/states/particlesegmentedcolorstate.ts"],"names":["ParticleSegmentedColorState","ParticleSegmentedColorState.constructor","ParticleSegmentedColorState.startColor","ParticleSegmentedColorState.endColor","ParticleSegmentedColorState.numSegmentPoint","ParticleSegmentedColorState.segmentPoints","ParticleSegmentedColorState.usesMultiplier","ParticleSegmentedColorState.usesOffset","ParticleSegmentedColorState.setRenderState","ParticleSegmentedColorState.updateColorData"],"mappings":"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WAAWA,CAACA,cAAcA,EAAEA,IAAIA,CAACA,WAAWA,CAACA,eAAeA,CAACA,CAACA;YAC/JA,GAAGA,CAACA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,GAAGA,IAAIA,CAACA,gBAAgBA,EAAEA,CAACA,EAAEA,EAAEA,CAACA;gBAC5CA,EAAEA,CAACA,CAACA,CAACA,IAAIA,CAACA,CAACA;oBACVA,IAAIA,CAACA,eAAeA,CAACA,IAAIA,CAACA,CAACA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA,KAAKA,CAACA,aAAaA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,aAAaA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA,KAAKA,CAACA,eAAeA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,eAAeA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA,KAAKA,CAACA,cAAcA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,cAAcA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA,KAAKA,CAACA,eAAeA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,eAAeA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,CAACA,CAACA;gBACzbA,IAAIA;oBACHA,IAAIA,CAACA,eAAeA,CAACA,IAAIA,CAACA,CAACA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA,KAAKA,CAACA,aAAaA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,GAAGA,CAACA,CAACA,CAACA,KAAKA,CAACA,aAAaA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA,KAAKA,CAACA,eAAeA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,GAAGA,CAACA,CAACA,CAACA,KAAKA,CAACA,eAAeA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA,KAAKA,CAACA,cAAcA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,GAAGA,CAACA,CAACA,CAACA,KAAKA,CAACA,cAAcA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA,KAAKA,CAACA,eAAeA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,GAAGA,CAACA,CAACA,CAACA,KAAKA,CAACA,eAAeA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,CAACA,CAACA;YAC1fA,CAACA;YACDA,EAAEA,CAACA,CAACA,IAAIA,CAACA,gBAAgBA,IAAIA,CAACA,CAACA;gBAC9BA,IAAIA,CAACA,eAAeA,CAACA,IAAIA,CAACA,IAAIA,CAACA,SAASA,CAACA,aAAaA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,aAAaA,EAAEA,IAAIA,CAACA,SAASA,CAACA,eAAeA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,eAAeA,EAAEA,IAAIA,CAACA,SAASA,CAACA,cAAcA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,cAAcA,EAAEA,IAAIA,CAACA,SAASA,CAACA,eAAeA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,eAAeA,CAACA,CAACA;YACjSA,IAAIA;gBACHA,IAAIA,CAACA,eAAeA,CAACA,IAAIA,CAACA,CAACA,IAAIA,CAACA,SAASA,CAACA,aAAaA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,GAAGA,CAACA,CAACA,CAACA,KAAKA,CAACA,aAAaA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,SAASA,CAACA,eAAeA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,GAAGA,CAACA,CAACA,CAACA,KAAKA,CAACA,eAAeA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,SAASA,CAACA,cAAcA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,GAAGA,CAACA,CAACA,CAACA,KAAKA,CAACA,cAAcA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,EAAEA,CAACA,IAAIA,CAACA,SAASA,CAACA,eAAeA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,GAAGA,CAACA,CAACA,CAACA,KAAKA,CAACA,eAAeA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,CAACA,CAACA;QAClcA,CAACA;QAEDA,EAAEA,CAACA,CAACA,IAAIA,CAACA,WAAWA,CAACA,CAACA,CAACA;YACtBA,IAAIA,CAACA,WAAWA,CAACA,IAAIA,CAACA,IAAIA,CAACA,WAAWA,CAACA,SAASA,GAACA,GAAGA,EAAEA,IAAIA,CAACA,WAAWA,CAACA,WAAWA,GAACA,GAAGA,EAAEA,IAAIA,CAACA,WAAWA,CAACA,UAAUA,GAACA,GAAGA,EAAEA,IAAIA,CAACA,WAAWA,CAACA,WAAWA,GAACA,GAAGA,CAACA,CAACA;YAC3JA,GAAGA,CAACA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,GAAGA,IAAIA,CAACA,gBAAgBA,EAAEA,CAACA,EAAEA,EAAEA,CAACA;gBAC5CA,EAAEA,CAACA,CAACA,CAACA,IAAIA,CAACA,CAACA;oBACVA,IAAIA,CAACA,WAAWA,CAACA,IAAIA,CAACA,CAACA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA,KAAKA,CAACA,SAASA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,SAASA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,GAACA,GAAGA,EAAEA,CAACA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA,KAAKA,CAACA,WAAWA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,WAAWA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,GAACA,GAAGA,EAAEA,CAACA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA,KAAKA,CAACA,UAAUA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,UAAUA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,GAACA,GAAGA,EAAEA,CAACA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA,KAAKA,CAACA,WAAWA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,WAAWA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,GAACA,GAAGA,CAACA,CAACA;gBACraA,IAAIA;oBACHA,IAAIA,CAACA,WAAWA,CAACA,IAAIA,CAACA,CAACA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA,KAAKA,CAACA,SAASA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,GAAGA,CAACA,CAACA,CAACA,KAAKA,CAACA,SAASA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,GAACA,GAAGA,EAAEA,CAACA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA,KAAKA,CAACA,WAAWA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,GAAGA,CAACA,CAACA,CAACA,KAAKA,CAACA,WAAWA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,GAACA,GAAGA,EAAEA,CAACA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA,KAAKA,CAACA,UAAUA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,GAAGA,CAACA,CAACA,CAACA,KAAKA,CAACA,UAAUA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,GAACA,GAAGA,EAAEA,CAACA,IAAIA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA,KAAKA,CAACA,WAAWA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,GAAGA,CAACA,CAACA,CAACA,KAAKA,CAACA,WAAWA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,GAACA,GAAGA,CAACA,CAACA;YACteA,CAACA;YACDA,EAAEA,CAACA,CAACA,IAAIA,CAACA,gBAAgBA,IAAIA,CAACA,CAACA;gBAC9BA,IAAIA,CAACA,WAAWA,CAACA,IAAIA,CAACA,CAACA,IAAIA,CAACA,SAASA,CAACA,SAASA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,SAASA,CAACA,GAACA,GAAGA,EAAEA,CAACA,IAAIA,CAACA,SAASA,CAACA,WAAWA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,WAAWA,CAACA,GAACA,GAAGA,EAAEA,CAACA,IAAIA,CAACA,SAASA,CAACA,UAAUA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,UAAUA,CAACA,GAACA,GAAGA,EAAEA,CAACA,IAAIA,CAACA,SAASA,CAACA,WAAWA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,WAAWA,CAACA,GAACA,GAAGA,CAACA,CAACA;YACrRA,IAAIA;gBACHA,IAAIA,CAACA,WAAWA,CAACA,IAAIA,CAACA,CAACA,IAAIA,CAACA,SAASA,CAACA,SAASA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,GAAGA,CAACA,CAACA,CAACA,KAAKA,CAACA,SAASA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,GAACA,GAAGA,EAAEA,CAACA,IAAIA,CAACA,SAASA,CAACA,WAAWA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,GAAGA,CAACA,CAACA,CAACA,KAAKA,CAACA,WAAWA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,GAACA,GAAGA,EAAEA,CAACA,IAAIA,CAACA,SAASA,CAACA,UAAUA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,GAAGA,CAACA,CAACA,CAACA,KAAKA,CAACA,UAAUA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,GAACA,GAAGA,EAAEA,CAACA,IAAIA,CAACA,SAASA,CAACA,WAAWA,GAAGA,IAAIA,CAACA,cAAcA,CAACA,CAACA,GAAGA,CAACA,CAACA,CAACA,KAAKA,CAACA,WAAWA,CAACA,GAACA,IAAIA,CAACA,aAAaA,CAACA,CAACA,CAACA,GAACA,GAAGA,CAACA,CAACA;QAC9aA,CAACA;QACDA,AACAA,kBADkBA;QAClBA,IAAIA,CAACA,aAAaA,CAACA,MAAMA,GAAGA,CAACA,CAACA;IAC/BA,CAACA;IAxJDT,eAAeA;IACDA,kDAAsBA,GAAmBA,CAACA,CAACA;IAEzDA,eAAeA;IACDA,8CAAkBA,GAAmBA,CAACA,CAACA;IAErDA,eAAeA;IACDA,2CAAeA,GAAmBA,CAACA,CAACA;IAkJnDA,kCAACA;AAADA,CA3JA,AA2JCA,EA3JyC,iBAAiB,EA2J1D;AAED,AAAqC,iBAA5B,2BAA2B,CAAC","file":"animators/states/ParticleSegmentedColorState.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import ColorTransform\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/ColorTransform\");\nimport Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\nimport Camera\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Camera\");\n\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport RenderableBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/RenderableBase\");\nimport ContextGLVertexBufferFormat\t\t= require(\"awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat\");\n\nimport ParticleAnimator\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimator\");\nimport AnimationSubGeometry\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/AnimationSubGeometry\");\nimport ColorSegmentPoint\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ColorSegmentPoint\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleSegmentedColorNode\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleSegmentedColorNode\");\nimport ParticleStateBase\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleStateBase\");\n\n/**\n *\n */\nclass ParticleSegmentedColorState extends ParticleStateBase\n{\n\t/** @private */\n\tpublic static START_MULTIPLIER_INDEX:number /*uint*/ = 0;\n\n\t/** @private */\n\tpublic static START_OFFSET_INDEX:number /*uint*/ = 1;\n\n\t/** @private */\n\tpublic static TIME_DATA_INDEX:number /*uint*/ = 2;\n\n\tprivate _usesMultiplier:boolean;\n\tprivate _usesOffset:boolean;\n\tprivate _startColor:ColorTransform;\n\tprivate _endColor:ColorTransform;\n\tprivate _segmentPoints:Array<ColorSegmentPoint>;\n\tprivate _numSegmentPoint:number /*int*/;\n\n\tprivate _timeLifeData:Array<number>;\n\tprivate _multiplierData:Array<number>;\n\tprivate _offsetData:Array<number>;\n\n\t/**\n\t * Defines the start color transform of the state, when in global mode.\n\t */\n\tpublic get startColor():ColorTransform\n\t{\n\t\treturn this._startColor;\n\t}\n\n\tpublic set startColor(value:ColorTransform)\n\t{\n\t\tthis._startColor = value;\n\n\t\tthis.updateColorData();\n\t}\n\n\t/**\n\t * Defines the end color transform of the state, when in global mode.\n\t */\n\tpublic get endColor():ColorTransform\n\t{\n\t\treturn this._endColor;\n\t}\n\n\tpublic set endColor(value:ColorTransform)\n\t{\n\t\tthis._endColor = value;\n\t\tthis.updateColorData();\n\t}\n\n\t/**\n\t * Defines the number of segments.\n\t */\n\tpublic get numSegmentPoint():number /*int*/\n\t{\n\t\treturn this._numSegmentPoint;\n\t}\n\n\t/**\n\t * Defines the key points of color\n\t */\n\tpublic get segmentPoints():Array<ColorSegmentPoint>\n\t{\n\t\treturn this._segmentPoints;\n\t}\n\n\tpublic set segmentPoints(value:Array<ColorSegmentPoint>)\n\t{\n\t\tthis._segmentPoints = value;\n\t\tthis.updateColorData();\n\t}\n\n\tpublic get usesMultiplier():boolean\n\t{\n\t\treturn this._usesMultiplier;\n\t}\n\n\tpublic get usesOffset():boolean\n\t{\n\t\treturn this._usesOffset;\n\t}\n\n\tconstructor(animator:ParticleAnimator, particleSegmentedColorNode:ParticleSegmentedColorNode)\n\t{\n\t\tsuper(animator, particleSegmentedColorNode);\n\n\t\tthis._usesMultiplier = particleSegmentedColorNode._iUsesMultiplier;\n\t\tthis._usesOffset = particleSegmentedColorNode._iUsesOffset;\n\t\tthis._startColor = particleSegmentedColorNode._iStartColor;\n\t\tthis._endColor = particleSegmentedColorNode._iEndColor;\n\t\tthis._segmentPoints = particleSegmentedColorNode._iSegmentPoints;\n\t\tthis._numSegmentPoint = particleSegmentedColorNode._iNumSegmentPoint;\n\t\tthis.updateColorData();\n\t}\n\n\tpublic setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)\n\t{\n\t\tif (animationRegisterCache.needFragmentAnimation) {\n\t\t\tif (this._numSegmentPoint > 0)\n\t\t\t\tanimationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleSegmentedColorState.TIME_DATA_INDEX), this._timeLifeData[0], this._timeLifeData[1], this._timeLifeData[2], this._timeLifeData[3]);\n\t\t\tif (this._usesMultiplier)\n\t\t\t\tanimationRegisterCache.setVertexConstFromArray(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleSegmentedColorState.START_MULTIPLIER_INDEX), this._multiplierData);\n\t\t\tif (this._usesOffset)\n\t\t\t\tanimationRegisterCache.setVertexConstFromArray(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleSegmentedColorState.START_OFFSET_INDEX), this._offsetData);\n\t\t}\n\t}\n\n\tprivate updateColorData()\n\t{\n\t\tthis._timeLifeData = new Array<number>();\n\t\tthis._multiplierData = new Array<number>();\n\t\tthis._offsetData = new Array<number>();\n\t\tvar i:number /*int*/;\n\t\tfor (i = 0; i < this._numSegmentPoint; i++) {\n\t\t\tif (i == 0)\n\t\t\t\tthis._timeLifeData.push(this._segmentPoints[i].life);\n\t\t\telse\n\t\t\t\tthis._timeLifeData.push(this._segmentPoints[i].life - this._segmentPoints[i - 1].life);\n\t\t}\n\t\tif (this._numSegmentPoint == 0)\n\t\t\tthis._timeLifeData.push(1);\n\t\telse\n\t\t\tthis._timeLifeData.push(1 - this._segmentPoints[i - 1].life);\n\n\t\tif (this._usesMultiplier) {\n\t\t\tthis._multiplierData.push(this._startColor.redMultiplier, this._startColor.greenMultiplier, this._startColor.blueMultiplier, this._startColor.alphaMultiplier);\n\t\t\tfor (i = 0; i < this._numSegmentPoint; i++) {\n\t\t\t\tif (i == 0)\n\t\t\t\t\tthis._multiplierData.push((this._segmentPoints[i].color.redMultiplier - this._startColor.redMultiplier)/this._timeLifeData[i], (this._segmentPoints[i].color.greenMultiplier - this._startColor.greenMultiplier)/this._timeLifeData[i], (this._segmentPoints[i].color.blueMultiplier - this._startColor.blueMultiplier)/this._timeLifeData[i], (this._segmentPoints[i].color.alphaMultiplier - this._startColor.alphaMultiplier)/this._timeLifeData[i]);\n\t\t\t\telse\n\t\t\t\t\tthis._multiplierData.push((this._segmentPoints[i].color.redMultiplier - this._segmentPoints[i - 1].color.redMultiplier)/this._timeLifeData[i], (this._segmentPoints[i].color.greenMultiplier - this._segmentPoints[i - 1].color.greenMultiplier)/this._timeLifeData[i], (this._segmentPoints[i].color.blueMultiplier - this._segmentPoints[i - 1].color.blueMultiplier)/this._timeLifeData[i], (this._segmentPoints[i].color.alphaMultiplier - this._segmentPoints[i - 1].color.alphaMultiplier)/this._timeLifeData[i]);\n\t\t\t}\n\t\t\tif (this._numSegmentPoint == 0)\n\t\t\t\tthis._multiplierData.push(this._endColor.redMultiplier - this._startColor.redMultiplier, this._endColor.greenMultiplier - this._startColor.greenMultiplier, this._endColor.blueMultiplier - this._startColor.blueMultiplier, this._endColor.alphaMultiplier - this._startColor.alphaMultiplier);\n\t\t\telse\n\t\t\t\tthis._multiplierData.push((this._endColor.redMultiplier - this._segmentPoints[i - 1].color.redMultiplier)/this._timeLifeData[i], (this._endColor.greenMultiplier - this._segmentPoints[i - 1].color.greenMultiplier)/this._timeLifeData[i], (this._endColor.blueMultiplier - this._segmentPoints[i - 1].color.blueMultiplier)/this._timeLifeData[i], (this._endColor.alphaMultiplier - this._segmentPoints[i - 1].color.alphaMultiplier)/this._timeLifeData[i]);\n\t\t}\n\n\t\tif (this._usesOffset) {\n\t\t\tthis._offsetData.push(this._startColor.redOffset/255, this._startColor.greenOffset/255, this._startColor.blueOffset/255, this._startColor.alphaOffset/255);\n\t\t\tfor (i = 0; i < this._numSegmentPoint; i++) {\n\t\t\t\tif (i == 0)\n\t\t\t\t\tthis._offsetData.push((this._segmentPoints[i].color.redOffset - this._startColor.redOffset)/this._timeLifeData[i]/255, (this._segmentPoints[i].color.greenOffset - this._startColor.greenOffset)/this._timeLifeData[i]/255, (this._segmentPoints[i].color.blueOffset - this._startColor.blueOffset)/this._timeLifeData[i]/255, (this._segmentPoints[i].color.alphaOffset - this._startColor.alphaOffset)/this._timeLifeData[i]/255);\n\t\t\t\telse\n\t\t\t\t\tthis._offsetData.push((this._segmentPoints[i].color.redOffset - this._segmentPoints[i - 1].color.redOffset)/this._timeLifeData[i]/255, (this._segmentPoints[i].color.greenOffset - this._segmentPoints[i - 1].color.greenOffset)/this._timeLifeData[i]/255, (this._segmentPoints[i].color.blueOffset - this._segmentPoints[i - 1].color.blueOffset)/this._timeLifeData[i]/255, (this._segmentPoints[i].color.alphaOffset - this._segmentPoints[i - 1].color.alphaOffset)/this._timeLifeData[i]/255);\n\t\t\t}\n\t\t\tif (this._numSegmentPoint == 0)\n\t\t\t\tthis._offsetData.push((this._endColor.redOffset - this._startColor.redOffset)/255, (this._endColor.greenOffset - this._startColor.greenOffset)/255, (this._endColor.blueOffset - this._startColor.blueOffset)/255, (this._endColor.alphaOffset - this._startColor.alphaOffset)/255);\n\t\t\telse\n\t\t\t\tthis._offsetData.push((this._endColor.redOffset - this._segmentPoints[i - 1].color.redOffset)/this._timeLifeData[i]/255, (this._endColor.greenOffset - this._segmentPoints[i - 1].color.greenOffset)/this._timeLifeData[i]/255, (this._endColor.blueOffset - this._segmentPoints[i - 1].color.blueOffset)/this._timeLifeData[i]/255, (this._endColor.alphaOffset - this._segmentPoints[i - 1].color.alphaOffset)/this._timeLifeData[i]/255);\n\t\t}\n\t\t//cut off the data\n\t\tthis._timeLifeData.length = 4;\n\t}\n}\n\nexport = ParticleSegmentedColorState;"]}
\ No newline at end of file
diff --git a/lib/animators/states/ParticleSegmentedColorState.ts b/lib/animators/states/ParticleSegmentedColorState.ts
new file mode 100644
index 000000000..8dff14261
--- /dev/null
+++ b/lib/animators/states/ParticleSegmentedColorState.ts
@@ -0,0 +1,177 @@
+import ColorTransform = require("awayjs-core/lib/core/geom/ColorTransform");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+
+import ParticleAnimator = require("awayjs-renderergl/lib/animators/ParticleAnimator");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ColorSegmentPoint = require("awayjs-renderergl/lib/animators/data/ColorSegmentPoint");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleSegmentedColorNode = require("awayjs-renderergl/lib/animators/nodes/ParticleSegmentedColorNode");
+import ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+
+/**
+ *
+ */
+class ParticleSegmentedColorState extends ParticleStateBase
+{
+ /** @private */
+ public static START_MULTIPLIER_INDEX:number /*uint*/ = 0;
+
+ /** @private */
+ public static START_OFFSET_INDEX:number /*uint*/ = 1;
+
+ /** @private */
+ public static TIME_DATA_INDEX:number /*uint*/ = 2;
+
+ private _usesMultiplier:boolean;
+ private _usesOffset:boolean;
+ private _startColor:ColorTransform;
+ private _endColor:ColorTransform;
+ private _segmentPoints:Array;
+ private _numSegmentPoint:number /*int*/;
+
+ private _timeLifeData:Array;
+ private _multiplierData:Array;
+ private _offsetData:Array;
+
+ /**
+ * Defines the start color transform of the state, when in global mode.
+ */
+ public get startColor():ColorTransform
+ {
+ return this._startColor;
+ }
+
+ public set startColor(value:ColorTransform)
+ {
+ this._startColor = value;
+
+ this.updateColorData();
+ }
+
+ /**
+ * Defines the end color transform of the state, when in global mode.
+ */
+ public get endColor():ColorTransform
+ {
+ return this._endColor;
+ }
+
+ public set endColor(value:ColorTransform)
+ {
+ this._endColor = value;
+ this.updateColorData();
+ }
+
+ /**
+ * Defines the number of segments.
+ */
+ public get numSegmentPoint():number /*int*/
+ {
+ return this._numSegmentPoint;
+ }
+
+ /**
+ * Defines the key points of color
+ */
+ public get segmentPoints():Array
+ {
+ return this._segmentPoints;
+ }
+
+ public set segmentPoints(value:Array)
+ {
+ this._segmentPoints = value;
+ this.updateColorData();
+ }
+
+ public get usesMultiplier():boolean
+ {
+ return this._usesMultiplier;
+ }
+
+ public get usesOffset():boolean
+ {
+ return this._usesOffset;
+ }
+
+ constructor(animator:ParticleAnimator, particleSegmentedColorNode:ParticleSegmentedColorNode)
+ {
+ super(animator, particleSegmentedColorNode);
+
+ this._usesMultiplier = particleSegmentedColorNode._iUsesMultiplier;
+ this._usesOffset = particleSegmentedColorNode._iUsesOffset;
+ this._startColor = particleSegmentedColorNode._iStartColor;
+ this._endColor = particleSegmentedColorNode._iEndColor;
+ this._segmentPoints = particleSegmentedColorNode._iSegmentPoints;
+ this._numSegmentPoint = particleSegmentedColorNode._iNumSegmentPoint;
+ this.updateColorData();
+ }
+
+ public setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)
+ {
+ if (animationRegisterCache.needFragmentAnimation) {
+ if (this._numSegmentPoint > 0)
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleSegmentedColorState.TIME_DATA_INDEX), this._timeLifeData[0], this._timeLifeData[1], this._timeLifeData[2], this._timeLifeData[3]);
+ if (this._usesMultiplier)
+ animationRegisterCache.setVertexConstFromArray(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleSegmentedColorState.START_MULTIPLIER_INDEX), this._multiplierData);
+ if (this._usesOffset)
+ animationRegisterCache.setVertexConstFromArray(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleSegmentedColorState.START_OFFSET_INDEX), this._offsetData);
+ }
+ }
+
+ private updateColorData()
+ {
+ this._timeLifeData = new Array();
+ this._multiplierData = new Array();
+ this._offsetData = new Array();
+ var i:number /*int*/;
+ for (i = 0; i < this._numSegmentPoint; i++) {
+ if (i == 0)
+ this._timeLifeData.push(this._segmentPoints[i].life);
+ else
+ this._timeLifeData.push(this._segmentPoints[i].life - this._segmentPoints[i - 1].life);
+ }
+ if (this._numSegmentPoint == 0)
+ this._timeLifeData.push(1);
+ else
+ this._timeLifeData.push(1 - this._segmentPoints[i - 1].life);
+
+ if (this._usesMultiplier) {
+ this._multiplierData.push(this._startColor.redMultiplier, this._startColor.greenMultiplier, this._startColor.blueMultiplier, this._startColor.alphaMultiplier);
+ for (i = 0; i < this._numSegmentPoint; i++) {
+ if (i == 0)
+ this._multiplierData.push((this._segmentPoints[i].color.redMultiplier - this._startColor.redMultiplier)/this._timeLifeData[i], (this._segmentPoints[i].color.greenMultiplier - this._startColor.greenMultiplier)/this._timeLifeData[i], (this._segmentPoints[i].color.blueMultiplier - this._startColor.blueMultiplier)/this._timeLifeData[i], (this._segmentPoints[i].color.alphaMultiplier - this._startColor.alphaMultiplier)/this._timeLifeData[i]);
+ else
+ this._multiplierData.push((this._segmentPoints[i].color.redMultiplier - this._segmentPoints[i - 1].color.redMultiplier)/this._timeLifeData[i], (this._segmentPoints[i].color.greenMultiplier - this._segmentPoints[i - 1].color.greenMultiplier)/this._timeLifeData[i], (this._segmentPoints[i].color.blueMultiplier - this._segmentPoints[i - 1].color.blueMultiplier)/this._timeLifeData[i], (this._segmentPoints[i].color.alphaMultiplier - this._segmentPoints[i - 1].color.alphaMultiplier)/this._timeLifeData[i]);
+ }
+ if (this._numSegmentPoint == 0)
+ this._multiplierData.push(this._endColor.redMultiplier - this._startColor.redMultiplier, this._endColor.greenMultiplier - this._startColor.greenMultiplier, this._endColor.blueMultiplier - this._startColor.blueMultiplier, this._endColor.alphaMultiplier - this._startColor.alphaMultiplier);
+ else
+ this._multiplierData.push((this._endColor.redMultiplier - this._segmentPoints[i - 1].color.redMultiplier)/this._timeLifeData[i], (this._endColor.greenMultiplier - this._segmentPoints[i - 1].color.greenMultiplier)/this._timeLifeData[i], (this._endColor.blueMultiplier - this._segmentPoints[i - 1].color.blueMultiplier)/this._timeLifeData[i], (this._endColor.alphaMultiplier - this._segmentPoints[i - 1].color.alphaMultiplier)/this._timeLifeData[i]);
+ }
+
+ if (this._usesOffset) {
+ this._offsetData.push(this._startColor.redOffset/255, this._startColor.greenOffset/255, this._startColor.blueOffset/255, this._startColor.alphaOffset/255);
+ for (i = 0; i < this._numSegmentPoint; i++) {
+ if (i == 0)
+ this._offsetData.push((this._segmentPoints[i].color.redOffset - this._startColor.redOffset)/this._timeLifeData[i]/255, (this._segmentPoints[i].color.greenOffset - this._startColor.greenOffset)/this._timeLifeData[i]/255, (this._segmentPoints[i].color.blueOffset - this._startColor.blueOffset)/this._timeLifeData[i]/255, (this._segmentPoints[i].color.alphaOffset - this._startColor.alphaOffset)/this._timeLifeData[i]/255);
+ else
+ this._offsetData.push((this._segmentPoints[i].color.redOffset - this._segmentPoints[i - 1].color.redOffset)/this._timeLifeData[i]/255, (this._segmentPoints[i].color.greenOffset - this._segmentPoints[i - 1].color.greenOffset)/this._timeLifeData[i]/255, (this._segmentPoints[i].color.blueOffset - this._segmentPoints[i - 1].color.blueOffset)/this._timeLifeData[i]/255, (this._segmentPoints[i].color.alphaOffset - this._segmentPoints[i - 1].color.alphaOffset)/this._timeLifeData[i]/255);
+ }
+ if (this._numSegmentPoint == 0)
+ this._offsetData.push((this._endColor.redOffset - this._startColor.redOffset)/255, (this._endColor.greenOffset - this._startColor.greenOffset)/255, (this._endColor.blueOffset - this._startColor.blueOffset)/255, (this._endColor.alphaOffset - this._startColor.alphaOffset)/255);
+ else
+ this._offsetData.push((this._endColor.redOffset - this._segmentPoints[i - 1].color.redOffset)/this._timeLifeData[i]/255, (this._endColor.greenOffset - this._segmentPoints[i - 1].color.greenOffset)/this._timeLifeData[i]/255, (this._endColor.blueOffset - this._segmentPoints[i - 1].color.blueOffset)/this._timeLifeData[i]/255, (this._endColor.alphaOffset - this._segmentPoints[i - 1].color.alphaOffset)/this._timeLifeData[i]/255);
+ }
+ //cut off the data
+ this._timeLifeData.length = 4;
+ }
+}
+
+export = ParticleSegmentedColorState;
\ No newline at end of file
diff --git a/lib/animators/states/ParticleSpriteSheetState.js b/lib/animators/states/ParticleSpriteSheetState.js
new file mode 100755
index 000000000..17993592b
--- /dev/null
+++ b/lib/animators/states/ParticleSpriteSheetState.js
@@ -0,0 +1,94 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+/**
+ * ...
+ */
+var ParticleSpriteSheetState = (function (_super) {
+ __extends(ParticleSpriteSheetState, _super);
+ function ParticleSpriteSheetState(animator, particleSpriteSheetNode) {
+ _super.call(this, animator, particleSpriteSheetNode);
+ this._particleSpriteSheetNode = particleSpriteSheetNode;
+ this._usesCycle = this._particleSpriteSheetNode._iUsesCycle;
+ this._usesPhase = this._particleSpriteSheetNode._iUsesCycle;
+ this._totalFrames = this._particleSpriteSheetNode._iTotalFrames;
+ this._numColumns = this._particleSpriteSheetNode._iNumColumns;
+ this._numRows = this._particleSpriteSheetNode._iNumRows;
+ this._cycleDuration = this._particleSpriteSheetNode._iCycleDuration;
+ this._cyclePhase = this._particleSpriteSheetNode._iCyclePhase;
+ this.updateSpriteSheetData();
+ }
+ Object.defineProperty(ParticleSpriteSheetState.prototype, "cyclePhase", {
+ /**
+ * Defines the cycle phase, when in global mode. Defaults to zero.
+ */
+ get: function () {
+ return this._cyclePhase;
+ },
+ set: function (value) {
+ this._cyclePhase = value;
+ this.updateSpriteSheetData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(ParticleSpriteSheetState.prototype, "cycleDuration", {
+ /**
+ * Defines the cycle duration in seconds, when in global mode. Defaults to 1.
+ */
+ get: function () {
+ return this._cycleDuration;
+ },
+ set: function (value) {
+ this._cycleDuration = value;
+ this.updateSpriteSheetData();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ ParticleSpriteSheetState.prototype.setRenderState = function (stage, renderable, animationSubGeometry, animationRegisterCache, camera) {
+ if (animationRegisterCache.needUVAnimation) {
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleSpriteSheetState.UV_INDEX_0), this._spriteSheetData[0], this._spriteSheetData[1], this._spriteSheetData[2], this._spriteSheetData[3]);
+ if (this._usesCycle) {
+ var index = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleSpriteSheetState.UV_INDEX_1);
+ if (this._particleSpriteSheetNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {
+ if (this._usesPhase)
+ animationSubGeometry.activateVertexBuffer(index, this._particleSpriteSheetNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ else
+ animationSubGeometry.activateVertexBuffer(index, this._particleSpriteSheetNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_2);
+ }
+ else
+ animationRegisterCache.setVertexConst(index, this._spriteSheetData[4], this._spriteSheetData[5]);
+ }
+ }
+ };
+ ParticleSpriteSheetState.prototype.updateSpriteSheetData = function () {
+ this._spriteSheetData = new Array(8);
+ var uTotal = this._totalFrames / this._numColumns;
+ this._spriteSheetData[0] = uTotal;
+ this._spriteSheetData[1] = 1 / this._numColumns;
+ this._spriteSheetData[2] = 1 / this._numRows;
+ if (this._usesCycle) {
+ if (this._cycleDuration <= 0)
+ throw (new Error("the cycle duration must be greater than zero"));
+ this._spriteSheetData[4] = uTotal / this._cycleDuration;
+ this._spriteSheetData[5] = this._cycleDuration;
+ if (this._usesPhase)
+ this._spriteSheetData[6] = this._cyclePhase;
+ }
+ };
+ /** @private */
+ ParticleSpriteSheetState.UV_INDEX_0 = 0;
+ /** @private */
+ ParticleSpriteSheetState.UV_INDEX_1 = 1;
+ return ParticleSpriteSheetState;
+})(ParticleStateBase);
+module.exports = ParticleSpriteSheetState;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/states/particlespritesheetstate.ts"],"names":["ParticleSpriteSheetState","ParticleSpriteSheetState.constructor","ParticleSpriteSheetState.cyclePhase","ParticleSpriteSheetState.cycleDuration","ParticleSpriteSheetState.setRenderState","ParticleSpriteSheetState.updateSpriteSheetData"],"mappings":"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","file":"animators/states/ParticleSpriteSheetState.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\nimport Camera\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Camera\");\n\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport RenderableBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/RenderableBase\");\nimport ContextGLVertexBufferFormat\t\t= require(\"awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat\");\n\nimport ParticleAnimator\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimator\");\nimport AnimationSubGeometry\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/AnimationSubGeometry\");\nimport ParticlePropertiesMode\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticlePropertiesMode\");\nimport ParticleSpriteSheetNode\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleSpriteSheetNode\");\nimport ParticleStateBase\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ParticleStateBase\");\n\n/**\n * ...\n */\nclass ParticleSpriteSheetState extends ParticleStateBase\n{\n\t/** @private */\n\tpublic static UV_INDEX_0:number /*uint*/ = 0;\n\n\t/** @private */\n\tpublic static UV_INDEX_1:number /*uint*/ = 1;\n\n\tprivate _particleSpriteSheetNode:ParticleSpriteSheetNode;\n\tprivate _usesCycle:boolean;\n\tprivate _usesPhase:boolean;\n\tprivate _totalFrames:number /*int*/;\n\tprivate _numColumns:number /*int*/;\n\tprivate _numRows:number /*int*/;\n\tprivate _cycleDuration:number;\n\tprivate _cyclePhase:number;\n\tprivate _spriteSheetData:Array<number>;\n\n\t/**\n\t * Defines the cycle phase, when in global mode. Defaults to zero.\n\t */\n\tpublic get cyclePhase():number\n\t{\n\t\treturn this._cyclePhase;\n\t}\n\n\tpublic set cyclePhase(value:number)\n\t{\n\t\tthis._cyclePhase = value;\n\n\t\tthis.updateSpriteSheetData();\n\t}\n\n\t/**\n\t * Defines the cycle duration in seconds, when in global mode. Defaults to 1.\n\t */\n\tpublic get cycleDuration():number\n\t{\n\t\treturn this._cycleDuration;\n\t}\n\n\tpublic set cycleDuration(value:number)\n\t{\n\t\tthis._cycleDuration = value;\n\n\t\tthis.updateSpriteSheetData();\n\t}\n\n\tconstructor(animator:ParticleAnimator, particleSpriteSheetNode:ParticleSpriteSheetNode)\n\t{\n\t\tsuper(animator, particleSpriteSheetNode);\n\n\t\tthis._particleSpriteSheetNode = particleSpriteSheetNode;\n\n\t\tthis._usesCycle = this._particleSpriteSheetNode._iUsesCycle;\n\t\tthis._usesPhase = this._particleSpriteSheetNode._iUsesCycle;\n\t\tthis._totalFrames = this._particleSpriteSheetNode._iTotalFrames;\n\t\tthis._numColumns = this._particleSpriteSheetNode._iNumColumns;\n\t\tthis._numRows = this._particleSpriteSheetNode._iNumRows;\n\t\tthis._cycleDuration = this._particleSpriteSheetNode._iCycleDuration;\n\t\tthis._cyclePhase = this._particleSpriteSheetNode._iCyclePhase;\n\n\t\tthis.updateSpriteSheetData();\n\t}\n\n\tpublic setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)\n\t{\n\t\tif (animationRegisterCache.needUVAnimation) {\n\t\t\tanimationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleSpriteSheetState.UV_INDEX_0), this._spriteSheetData[0], this._spriteSheetData[1], this._spriteSheetData[2], this._spriteSheetData[3]);\n\t\t\tif (this._usesCycle) {\n\t\t\t\tvar index:number /*int*/ = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleSpriteSheetState.UV_INDEX_1);\n\t\t\t\tif (this._particleSpriteSheetNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {\n\t\t\t\t\tif (this._usesPhase)\n\t\t\t\t\t\tanimationSubGeometry.activateVertexBuffer(index, this._particleSpriteSheetNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);\n\t\t\t\t\telse\n\t\t\t\t\t\tanimationSubGeometry.activateVertexBuffer(index, this._particleSpriteSheetNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_2);\n\t\t\t\t} else\n\t\t\t\t\tanimationRegisterCache.setVertexConst(index, this._spriteSheetData[4], this._spriteSheetData[5]);\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate updateSpriteSheetData()\n\t{\n\t\tthis._spriteSheetData = new Array<number>(8);\n\n\t\tvar uTotal:number = this._totalFrames/this._numColumns;\n\n\t\tthis._spriteSheetData[0] = uTotal;\n\t\tthis._spriteSheetData[1] = 1/this._numColumns;\n\t\tthis._spriteSheetData[2] = 1/this._numRows;\n\n\t\tif (this._usesCycle) {\n\t\t\tif (this._cycleDuration <= 0)\n\t\t\t\tthrow(new Error(\"the cycle duration must be greater than zero\"));\n\t\t\tthis._spriteSheetData[4] = uTotal/this._cycleDuration;\n\t\t\tthis._spriteSheetData[5] = this._cycleDuration;\n\t\t\tif (this._usesPhase)\n\t\t\t\tthis._spriteSheetData[6] = this._cyclePhase;\n\t\t}\n\t}\n}\n\nexport = ParticleSpriteSheetState;"]}
\ No newline at end of file
diff --git a/lib/animators/states/ParticleSpriteSheetState.ts b/lib/animators/states/ParticleSpriteSheetState.ts
new file mode 100644
index 000000000..39952bb94
--- /dev/null
+++ b/lib/animators/states/ParticleSpriteSheetState.ts
@@ -0,0 +1,121 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+
+import ParticleAnimator = require("awayjs-renderergl/lib/animators/ParticleAnimator");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleSpriteSheetNode = require("awayjs-renderergl/lib/animators/nodes/ParticleSpriteSheetNode");
+import ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+
+/**
+ * ...
+ */
+class ParticleSpriteSheetState extends ParticleStateBase
+{
+ /** @private */
+ public static UV_INDEX_0:number /*uint*/ = 0;
+
+ /** @private */
+ public static UV_INDEX_1:number /*uint*/ = 1;
+
+ private _particleSpriteSheetNode:ParticleSpriteSheetNode;
+ private _usesCycle:boolean;
+ private _usesPhase:boolean;
+ private _totalFrames:number /*int*/;
+ private _numColumns:number /*int*/;
+ private _numRows:number /*int*/;
+ private _cycleDuration:number;
+ private _cyclePhase:number;
+ private _spriteSheetData:Array;
+
+ /**
+ * Defines the cycle phase, when in global mode. Defaults to zero.
+ */
+ public get cyclePhase():number
+ {
+ return this._cyclePhase;
+ }
+
+ public set cyclePhase(value:number)
+ {
+ this._cyclePhase = value;
+
+ this.updateSpriteSheetData();
+ }
+
+ /**
+ * Defines the cycle duration in seconds, when in global mode. Defaults to 1.
+ */
+ public get cycleDuration():number
+ {
+ return this._cycleDuration;
+ }
+
+ public set cycleDuration(value:number)
+ {
+ this._cycleDuration = value;
+
+ this.updateSpriteSheetData();
+ }
+
+ constructor(animator:ParticleAnimator, particleSpriteSheetNode:ParticleSpriteSheetNode)
+ {
+ super(animator, particleSpriteSheetNode);
+
+ this._particleSpriteSheetNode = particleSpriteSheetNode;
+
+ this._usesCycle = this._particleSpriteSheetNode._iUsesCycle;
+ this._usesPhase = this._particleSpriteSheetNode._iUsesCycle;
+ this._totalFrames = this._particleSpriteSheetNode._iTotalFrames;
+ this._numColumns = this._particleSpriteSheetNode._iNumColumns;
+ this._numRows = this._particleSpriteSheetNode._iNumRows;
+ this._cycleDuration = this._particleSpriteSheetNode._iCycleDuration;
+ this._cyclePhase = this._particleSpriteSheetNode._iCyclePhase;
+
+ this.updateSpriteSheetData();
+ }
+
+ public setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)
+ {
+ if (animationRegisterCache.needUVAnimation) {
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleSpriteSheetState.UV_INDEX_0), this._spriteSheetData[0], this._spriteSheetData[1], this._spriteSheetData[2], this._spriteSheetData[3]);
+ if (this._usesCycle) {
+ var index:number /*int*/ = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleSpriteSheetState.UV_INDEX_1);
+ if (this._particleSpriteSheetNode.mode == ParticlePropertiesMode.LOCAL_STATIC) {
+ if (this._usesPhase)
+ animationSubGeometry.activateVertexBuffer(index, this._particleSpriteSheetNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ else
+ animationSubGeometry.activateVertexBuffer(index, this._particleSpriteSheetNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_2);
+ } else
+ animationRegisterCache.setVertexConst(index, this._spriteSheetData[4], this._spriteSheetData[5]);
+ }
+ }
+ }
+
+ private updateSpriteSheetData()
+ {
+ this._spriteSheetData = new Array(8);
+
+ var uTotal:number = this._totalFrames/this._numColumns;
+
+ this._spriteSheetData[0] = uTotal;
+ this._spriteSheetData[1] = 1/this._numColumns;
+ this._spriteSheetData[2] = 1/this._numRows;
+
+ if (this._usesCycle) {
+ if (this._cycleDuration <= 0)
+ throw(new Error("the cycle duration must be greater than zero"));
+ this._spriteSheetData[4] = uTotal/this._cycleDuration;
+ this._spriteSheetData[5] = this._cycleDuration;
+ if (this._usesPhase)
+ this._spriteSheetData[6] = this._cyclePhase;
+ }
+ }
+}
+
+export = ParticleSpriteSheetState;
\ No newline at end of file
diff --git a/lib/animators/states/ParticleStateBase.js b/lib/animators/states/ParticleStateBase.js
new file mode 100755
index 000000000..d1f276583
--- /dev/null
+++ b/lib/animators/states/ParticleStateBase.js
@@ -0,0 +1,74 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var AnimationStateBase = require("awayjs-renderergl/lib/animators/states/AnimationStateBase");
+/**
+ * ...
+ */
+var ParticleStateBase = (function (_super) {
+ __extends(ParticleStateBase, _super);
+ function ParticleStateBase(animator, particleNode, needUpdateTime) {
+ if (needUpdateTime === void 0) { needUpdateTime = false; }
+ _super.call(this, animator, particleNode);
+ this._pDynamicProperties = new Array();
+ this._pDynamicPropertiesDirty = new Object();
+ this._particleNode = particleNode;
+ this._pNeedUpdateTime = needUpdateTime;
+ }
+ Object.defineProperty(ParticleStateBase.prototype, "needUpdateTime", {
+ get: function () {
+ return this._pNeedUpdateTime;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ ParticleStateBase.prototype.setRenderState = function (stage, renderable, animationSubGeometry, animationRegisterCache, camera) {
+ };
+ ParticleStateBase.prototype._pUpdateDynamicProperties = function (animationSubGeometry) {
+ this._pDynamicPropertiesDirty[animationSubGeometry._iUniqueId] = true;
+ var animationParticles = animationSubGeometry.animationParticles;
+ var vertexData = animationSubGeometry.vertexData;
+ var totalLenOfOneVertex = animationSubGeometry.totalLenOfOneVertex;
+ var dataLength = this._particleNode.dataLength;
+ var dataOffset = this._particleNode._iDataOffset;
+ var vertexLength /*uint*/;
+ // var particleOffset:number /*uint*/;
+ var startingOffset /*uint*/;
+ var vertexOffset /*uint*/;
+ var data;
+ var animationParticle;
+ // var numParticles:number /*uint*/ = _positions.length/dataLength;
+ var numParticles = this._pDynamicProperties.length;
+ var i = 0;
+ var j = 0;
+ var k = 0;
+ while (i < numParticles) {
+ while (j < numParticles && (animationParticle = animationParticles[j]).index == i) {
+ data = this._pDynamicProperties[i];
+ vertexLength = animationParticle.numVertices * totalLenOfOneVertex;
+ startingOffset = animationParticle.startVertexIndex * totalLenOfOneVertex + dataOffset;
+ for (k = 0; k < vertexLength; k += totalLenOfOneVertex) {
+ vertexOffset = startingOffset + k;
+ for (k = 0; k < vertexLength; k += totalLenOfOneVertex) {
+ vertexOffset = startingOffset + k;
+ vertexData[vertexOffset++] = data.x;
+ vertexData[vertexOffset++] = data.y;
+ vertexData[vertexOffset++] = data.z;
+ if (dataLength == 4)
+ vertexData[vertexOffset++] = data.w;
+ }
+ }
+ j++;
+ }
+ i++;
+ }
+ animationSubGeometry.invalidateBuffer();
+ };
+ return ParticleStateBase;
+})(AnimationStateBase);
+module.exports = ParticleStateBase;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/states/particlestatebase.ts"],"names":["ParticleStateBase","ParticleStateBase.constructor","ParticleStateBase.needUpdateTime","ParticleStateBase.setRenderState","ParticleStateBase._pUpdateDynamicProperties"],"mappings":"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","file":"animators/states/ParticleStateBase.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\nimport Camera\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Camera\");\n\nimport AnimationRegisterCache\t\t\t= require(\"awayjs-stagegl/lib/animators/data/AnimationRegisterCache\");\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport RenderableBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/RenderableBase\");\n\nimport ParticleAnimator\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/ParticleAnimator\");\nimport AnimationSubGeometry\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/AnimationSubGeometry\");\nimport ParticleAnimationData\t\t\t= require(\"awayjs-renderergl/lib/animators/data/ParticleAnimationData\");\nimport ParticleNodeBase\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/ParticleNodeBase\");\nimport AnimationStateBase\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/AnimationStateBase\");\n\n/**\n * ...\n */\nclass ParticleStateBase extends AnimationStateBase\n{\n\tprivate _particleNode:ParticleNodeBase;\n\n\tpublic _pDynamicProperties:Array<Vector3D> = new Array<Vector3D>();\n\tpublic _pDynamicPropertiesDirty:Object = new Object();\n\n\tpublic _pNeedUpdateTime:boolean;\n\n\tconstructor(animator:ParticleAnimator, particleNode:ParticleNodeBase, needUpdateTime:boolean = false)\n\t{\n\t\tsuper(animator, particleNode);\n\n\t\tthis._particleNode = particleNode;\n\t\tthis._pNeedUpdateTime = needUpdateTime;\n\t}\n\n\tpublic get needUpdateTime():boolean\n\t{\n\t\treturn this._pNeedUpdateTime;\n\t}\n\n\tpublic setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)\n\t{\n\n\t}\n\n\tpublic _pUpdateDynamicProperties(animationSubGeometry:AnimationSubGeometry)\n\t{\n\t\tthis._pDynamicPropertiesDirty[animationSubGeometry._iUniqueId] = true;\n\n\t\tvar animationParticles:Array<ParticleAnimationData> = animationSubGeometry.animationParticles;\n\t\tvar vertexData:Array<number> = animationSubGeometry.vertexData;\n\t\tvar totalLenOfOneVertex:number /*uint*/ = animationSubGeometry.totalLenOfOneVertex;\n\t\tvar dataLength:number /*uint*/ = this._particleNode.dataLength;\n\t\tvar dataOffset:number /*uint*/ = this._particleNode._iDataOffset;\n\t\tvar vertexLength:number /*uint*/;\n\t\t//\t\t\tvar particleOffset:number /*uint*/;\n\t\tvar startingOffset:number /*uint*/;\n\t\tvar vertexOffset:number /*uint*/;\n\t\tvar data:Vector3D;\n\t\tvar animationParticle:ParticleAnimationData;\n\n\t\t//\t\t\tvar numParticles:number /*uint*/ = _positions.length/dataLength;\n\t\tvar numParticles:number /*uint*/ = this._pDynamicProperties.length;\n\t\tvar i:number /*uint*/ = 0;\n\t\tvar j:number /*uint*/ = 0;\n\t\tvar k:number /*uint*/ = 0;\n\n\t\t//loop through all particles\n\t\twhile (i < numParticles) {\n\t\t\t//loop through each particle data for the current particle\n\t\t\twhile (j < numParticles && (animationParticle = animationParticles[j]).index == i) {\n\t\t\t\tdata = this._pDynamicProperties[i];\n\t\t\t\tvertexLength = animationParticle.numVertices*totalLenOfOneVertex;\n\t\t\t\tstartingOffset = animationParticle.startVertexIndex*totalLenOfOneVertex + dataOffset;\n\t\t\t\t//loop through each vertex in the particle data\n\t\t\t\tfor (k = 0; k < vertexLength; k += totalLenOfOneVertex) {\n\t\t\t\t\tvertexOffset = startingOffset + k;\n\t\t\t\t\t//\t\t\t\t\t\tparticleOffset = i * dataLength;\n\t\t\t\t\t//loop through all vertex data for the current particle data\n\t\t\t\t\tfor (k = 0; k < vertexLength; k += totalLenOfOneVertex) {\n\t\t\t\t\t\tvertexOffset = startingOffset + k;\n\t\t\t\t\t\tvertexData[vertexOffset++] = data.x;\n\t\t\t\t\t\tvertexData[vertexOffset++] = data.y;\n\t\t\t\t\t\tvertexData[vertexOffset++] = data.z;\n\n\t\t\t\t\t\tif (dataLength == 4)\n\t\t\t\t\t\t\tvertexData[vertexOffset++] = data.w;\n\t\t\t\t\t}\n\t\t\t\t\t\t//loop through each value in the particle vertex\n\t\t\t\t\t\t//\t\t\t\t\t\tswitch(dataLength) {\n\t\t\t\t\t\t//\t\t\t\t\t\t\tcase 4:\n\t\t\t\t\t\t//\t\t\t\t\t\t\t\tvertexData[vertexOffset++] = _positions[particleOffset++];\n\t\t\t\t\t\t//\t\t\t\t\t\t\tcase 3:\n\t\t\t\t\t\t//\t\t\t\t\t\t\t\tvertexData[vertexOffset++] = _positions[particleOffset++];\n\t\t\t\t\t\t//\t\t\t\t\t\t\tcase 2:\n\t\t\t\t\t\t//\t\t\t\t\t\t\t\tvertexData[vertexOffset++] = _positions[particleOffset++];\n\t\t\t\t\t\t//\t\t\t\t\t\t\tcase 1:\n\t\t\t\t\t\t//\t\t\t\t\t\t\t\tvertexData[vertexOffset++] = _positions[particleOffset++];\n\t\t\t\t\t\t//\t\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tj++;\n\t\t\t}\n\t\t\ti++;\n\t\t}\n\n\t\tanimationSubGeometry.invalidateBuffer();\n\t}\n\n}\n\nexport = ParticleStateBase;"]}
\ No newline at end of file
diff --git a/lib/animators/states/ParticleStateBase.ts b/lib/animators/states/ParticleStateBase.ts
new file mode 100644
index 000000000..919d4c083
--- /dev/null
+++ b/lib/animators/states/ParticleStateBase.ts
@@ -0,0 +1,109 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+
+import ParticleAnimator = require("awayjs-renderergl/lib/animators/ParticleAnimator");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticleAnimationData = require("awayjs-renderergl/lib/animators/data/ParticleAnimationData");
+import ParticleNodeBase = require("awayjs-renderergl/lib/animators/nodes/ParticleNodeBase");
+import AnimationStateBase = require("awayjs-renderergl/lib/animators/states/AnimationStateBase");
+
+/**
+ * ...
+ */
+class ParticleStateBase extends AnimationStateBase
+{
+ private _particleNode:ParticleNodeBase;
+
+ public _pDynamicProperties:Array = new Array();
+ public _pDynamicPropertiesDirty:Object = new Object();
+
+ public _pNeedUpdateTime:boolean;
+
+ constructor(animator:ParticleAnimator, particleNode:ParticleNodeBase, needUpdateTime:boolean = false)
+ {
+ super(animator, particleNode);
+
+ this._particleNode = particleNode;
+ this._pNeedUpdateTime = needUpdateTime;
+ }
+
+ public get needUpdateTime():boolean
+ {
+ return this._pNeedUpdateTime;
+ }
+
+ public setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)
+ {
+
+ }
+
+ public _pUpdateDynamicProperties(animationSubGeometry:AnimationSubGeometry)
+ {
+ this._pDynamicPropertiesDirty[animationSubGeometry._iUniqueId] = true;
+
+ var animationParticles:Array = animationSubGeometry.animationParticles;
+ var vertexData:Array = animationSubGeometry.vertexData;
+ var totalLenOfOneVertex:number /*uint*/ = animationSubGeometry.totalLenOfOneVertex;
+ var dataLength:number /*uint*/ = this._particleNode.dataLength;
+ var dataOffset:number /*uint*/ = this._particleNode._iDataOffset;
+ var vertexLength:number /*uint*/;
+ // var particleOffset:number /*uint*/;
+ var startingOffset:number /*uint*/;
+ var vertexOffset:number /*uint*/;
+ var data:Vector3D;
+ var animationParticle:ParticleAnimationData;
+
+ // var numParticles:number /*uint*/ = _positions.length/dataLength;
+ var numParticles:number /*uint*/ = this._pDynamicProperties.length;
+ var i:number /*uint*/ = 0;
+ var j:number /*uint*/ = 0;
+ var k:number /*uint*/ = 0;
+
+ //loop through all particles
+ while (i < numParticles) {
+ //loop through each particle data for the current particle
+ while (j < numParticles && (animationParticle = animationParticles[j]).index == i) {
+ data = this._pDynamicProperties[i];
+ vertexLength = animationParticle.numVertices*totalLenOfOneVertex;
+ startingOffset = animationParticle.startVertexIndex*totalLenOfOneVertex + dataOffset;
+ //loop through each vertex in the particle data
+ for (k = 0; k < vertexLength; k += totalLenOfOneVertex) {
+ vertexOffset = startingOffset + k;
+ // particleOffset = i * dataLength;
+ //loop through all vertex data for the current particle data
+ for (k = 0; k < vertexLength; k += totalLenOfOneVertex) {
+ vertexOffset = startingOffset + k;
+ vertexData[vertexOffset++] = data.x;
+ vertexData[vertexOffset++] = data.y;
+ vertexData[vertexOffset++] = data.z;
+
+ if (dataLength == 4)
+ vertexData[vertexOffset++] = data.w;
+ }
+ //loop through each value in the particle vertex
+ // switch(dataLength) {
+ // case 4:
+ // vertexData[vertexOffset++] = _positions[particleOffset++];
+ // case 3:
+ // vertexData[vertexOffset++] = _positions[particleOffset++];
+ // case 2:
+ // vertexData[vertexOffset++] = _positions[particleOffset++];
+ // case 1:
+ // vertexData[vertexOffset++] = _positions[particleOffset++];
+ // }
+ }
+ j++;
+ }
+ i++;
+ }
+
+ animationSubGeometry.invalidateBuffer();
+ }
+
+}
+
+export = ParticleStateBase;
\ No newline at end of file
diff --git a/lib/animators/states/ParticleTimeState.js b/lib/animators/states/ParticleTimeState.js
new file mode 100755
index 000000000..51594a7e4
--- /dev/null
+++ b/lib/animators/states/ParticleTimeState.js
@@ -0,0 +1,31 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+var ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+/**
+ * ...
+ */
+var ParticleTimeState = (function (_super) {
+ __extends(ParticleTimeState, _super);
+ function ParticleTimeState(animator, particleTimeNode) {
+ _super.call(this, animator, particleTimeNode, true);
+ this._particleTimeNode = particleTimeNode;
+ }
+ ParticleTimeState.prototype.setRenderState = function (stage, renderable, animationSubGeometry, animationRegisterCache, camera) {
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleTimeState.TIME_STREAM_INDEX), this._particleTimeNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+ var particleTime = this._pTime / 1000;
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleTimeState.TIME_CONSTANT_INDEX), particleTime, particleTime, particleTime, particleTime);
+ };
+ /** @private */
+ ParticleTimeState.TIME_STREAM_INDEX = 0;
+ /** @private */
+ ParticleTimeState.TIME_CONSTANT_INDEX = 1;
+ return ParticleTimeState;
+})(ParticleStateBase);
+module.exports = ParticleTimeState;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9zdGF0ZXMvcGFydGljbGV0aW1lc3RhdGUudHMiXSwibmFtZXMiOlsiUGFydGljbGVUaW1lU3RhdGUiLCJQYXJ0aWNsZVRpbWVTdGF0ZS5jb25zdHJ1Y3RvciIsIlBhcnRpY2xlVGltZVN0YXRlLnNldFJlbmRlclN0YXRlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFLQSxJQUFPLDJCQUEyQixXQUFZLDZEQUE2RCxDQUFDLENBQUM7QUFNN0csSUFBTyxpQkFBaUIsV0FBYywwREFBMEQsQ0FBQyxDQUFDO0FBRWxHLEFBR0E7O0dBREc7SUFDRyxpQkFBaUI7SUFBU0EsVUFBMUJBLGlCQUFpQkEsVUFBMEJBO0lBVWhEQSxTQVZLQSxpQkFBaUJBLENBVVZBLFFBQXlCQSxFQUFFQSxnQkFBaUNBO1FBRXZFQyxrQkFBTUEsUUFBUUEsRUFBRUEsZ0JBQWdCQSxFQUFFQSxJQUFJQSxDQUFDQSxDQUFDQTtRQUV4Q0EsSUFBSUEsQ0FBQ0EsaUJBQWlCQSxHQUFHQSxnQkFBZ0JBLENBQUNBO0lBQzNDQSxDQUFDQTtJQUVNRCwwQ0FBY0EsR0FBckJBLFVBQXNCQSxLQUFXQSxFQUFFQSxVQUF5QkEsRUFBRUEsb0JBQXlDQSxFQUFFQSxzQkFBNkNBLEVBQUVBLE1BQWFBO1FBRXBLRSxvQkFBb0JBLENBQUNBLG9CQUFvQkEsQ0FBQ0Esc0JBQXNCQSxDQUFDQSxnQkFBZ0JBLENBQUNBLElBQUlBLENBQUNBLGVBQWVBLEVBQUVBLGlCQUFpQkEsQ0FBQ0EsaUJBQWlCQSxDQUFDQSxFQUFFQSxJQUFJQSxDQUFDQSxpQkFBaUJBLENBQUNBLFlBQVlBLEVBQUVBLEtBQUtBLEVBQUVBLDJCQUEyQkEsQ0FBQ0EsT0FBT0EsQ0FBQ0EsQ0FBQ0E7UUFFL05BLElBQUlBLFlBQVlBLEdBQVVBLElBQUlBLENBQUNBLE1BQU1BLEdBQUNBLElBQUlBLENBQUNBO1FBQzNDQSxzQkFBc0JBLENBQUNBLGNBQWNBLENBQUNBLHNCQUFzQkEsQ0FBQ0EsZ0JBQWdCQSxDQUFDQSxJQUFJQSxDQUFDQSxlQUFlQSxFQUFFQSxpQkFBaUJBLENBQUNBLG1CQUFtQkEsQ0FBQ0EsRUFBRUEsWUFBWUEsRUFBRUEsWUFBWUEsRUFBRUEsWUFBWUEsRUFBRUEsWUFBWUEsQ0FBQ0EsQ0FBQ0E7SUFDck1BLENBQUNBO0lBckJERixlQUFlQTtJQUNEQSxtQ0FBaUJBLEdBQW1CQSxDQUFDQSxDQUFDQTtJQUVwREEsZUFBZUE7SUFDREEscUNBQW1CQSxHQUFtQkEsQ0FBQ0EsQ0FBQ0E7SUFtQnZEQSx3QkFBQ0E7QUFBREEsQ0F6QkEsQUF5QkNBLEVBekIrQixpQkFBaUIsRUF5QmhEO0FBRUQsQUFBMkIsaUJBQWxCLGlCQUFpQixDQUFDIiwiZmlsZSI6ImFuaW1hdG9ycy9zdGF0ZXMvUGFydGljbGVUaW1lU3RhdGUuanMiLCJzb3VyY2VSb290IjoiL1VzZXJzL3JvYmJhdGVtYW4vV2Vic3Rvcm1Qcm9qZWN0cy9hd2F5anMtcmVuZGVyZXJnbC8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQ2FtZXJhXHRcdFx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvZW50aXRpZXMvQ2FtZXJhXCIpO1xuXG5pbXBvcnQgQW5pbWF0aW9uUmVnaXN0ZXJDYWNoZVx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1zdGFnZWdsL2xpYi9hbmltYXRvcnMvZGF0YS9BbmltYXRpb25SZWdpc3RlckNhY2hlXCIpO1xuaW1wb3J0IFN0YWdlXHRcdFx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvY29yZS9iYXNlL1N0YWdlXCIpO1xuaW1wb3J0IFJlbmRlcmFibGVCYXNlXHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1zdGFnZWdsL2xpYi9jb3JlL3Bvb2wvUmVuZGVyYWJsZUJhc2VcIik7XG5pbXBvcnQgQ29udGV4dEdMVmVydGV4QnVmZmVyRm9ybWF0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1zdGFnZWdsL2xpYi9jb3JlL3N0YWdlZ2wvQ29udGV4dEdMVmVydGV4QnVmZmVyRm9ybWF0XCIpO1xuXG5pbXBvcnQgUGFydGljbGVBbmltYXRvclx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL1BhcnRpY2xlQW5pbWF0b3JcIik7XG5pbXBvcnQgQW5pbWF0aW9uU3ViR2VvbWV0cnlcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvZGF0YS9BbmltYXRpb25TdWJHZW9tZXRyeVwiKTtcbmltcG9ydCBQYXJ0aWNsZVByb3BlcnRpZXNNb2RlXHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXJlbmRlcmVyZ2wvbGliL2FuaW1hdG9ycy9kYXRhL1BhcnRpY2xlUHJvcGVydGllc01vZGVcIik7XG5pbXBvcnQgUGFydGljbGVUaW1lTm9kZVx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL25vZGVzL1BhcnRpY2xlVGltZU5vZGVcIik7XG5pbXBvcnQgUGFydGljbGVTdGF0ZUJhc2VcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvc3RhdGVzL1BhcnRpY2xlU3RhdGVCYXNlXCIpO1xuXG4vKipcbiAqIC4uLlxuICovXG5jbGFzcyBQYXJ0aWNsZVRpbWVTdGF0ZSBleHRlbmRzIFBhcnRpY2xlU3RhdGVCYXNlXG57XG5cdC8qKiBAcHJpdmF0ZSAqL1xuXHRwdWJsaWMgc3RhdGljIFRJTUVfU1RSRUFNX0lOREVYOm51bWJlciAvKnVpbnQqLyA9IDA7XG5cblx0LyoqIEBwcml2YXRlICovXG5cdHB1YmxpYyBzdGF0aWMgVElNRV9DT05TVEFOVF9JTkRFWDpudW1iZXIgLyp1aW50Ki8gPSAxO1xuXG5cdHByaXZhdGUgX3BhcnRpY2xlVGltZU5vZGU6UGFydGljbGVUaW1lTm9kZTtcblxuXHRjb25zdHJ1Y3RvcihhbmltYXRvcjpQYXJ0aWNsZUFuaW1hdG9yLCBwYXJ0aWNsZVRpbWVOb2RlOlBhcnRpY2xlVGltZU5vZGUpXG5cdHtcblx0XHRzdXBlcihhbmltYXRvciwgcGFydGljbGVUaW1lTm9kZSwgdHJ1ZSk7XG5cblx0XHR0aGlzLl9wYXJ0aWNsZVRpbWVOb2RlID0gcGFydGljbGVUaW1lTm9kZTtcblx0fVxuXG5cdHB1YmxpYyBzZXRSZW5kZXJTdGF0ZShzdGFnZTpTdGFnZSwgcmVuZGVyYWJsZTpSZW5kZXJhYmxlQmFzZSwgYW5pbWF0aW9uU3ViR2VvbWV0cnk6QW5pbWF0aW9uU3ViR2VvbWV0cnksIGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGU6QW5pbWF0aW9uUmVnaXN0ZXJDYWNoZSwgY2FtZXJhOkNhbWVyYSlcblx0e1xuXHRcdGFuaW1hdGlvblN1Ykdlb21ldHJ5LmFjdGl2YXRlVmVydGV4QnVmZmVyKGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGUuZ2V0UmVnaXN0ZXJJbmRleCh0aGlzLl9wQW5pbWF0aW9uTm9kZSwgUGFydGljbGVUaW1lU3RhdGUuVElNRV9TVFJFQU1fSU5ERVgpLCB0aGlzLl9wYXJ0aWNsZVRpbWVOb2RlLl9pRGF0YU9mZnNldCwgc3RhZ2UsIENvbnRleHRHTFZlcnRleEJ1ZmZlckZvcm1hdC5GTE9BVF80KTtcblxuXHRcdHZhciBwYXJ0aWNsZVRpbWU6bnVtYmVyID0gdGhpcy5fcFRpbWUvMTAwMDtcblx0XHRhbmltYXRpb25SZWdpc3RlckNhY2hlLnNldFZlcnRleENvbnN0KGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGUuZ2V0UmVnaXN0ZXJJbmRleCh0aGlzLl9wQW5pbWF0aW9uTm9kZSwgUGFydGljbGVUaW1lU3RhdGUuVElNRV9DT05TVEFOVF9JTkRFWCksIHBhcnRpY2xlVGltZSwgcGFydGljbGVUaW1lLCBwYXJ0aWNsZVRpbWUsIHBhcnRpY2xlVGltZSk7XG5cdH1cblxufVxuXG5leHBvcnQgPSBQYXJ0aWNsZVRpbWVTdGF0ZTsiXX0=
\ No newline at end of file
diff --git a/lib/animators/states/ParticleTimeState.ts b/lib/animators/states/ParticleTimeState.ts
new file mode 100644
index 000000000..2f6ee07e8
--- /dev/null
+++ b/lib/animators/states/ParticleTimeState.ts
@@ -0,0 +1,44 @@
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+
+import ParticleAnimator = require("awayjs-renderergl/lib/animators/ParticleAnimator");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleTimeNode = require("awayjs-renderergl/lib/animators/nodes/ParticleTimeNode");
+import ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+
+/**
+ * ...
+ */
+class ParticleTimeState extends ParticleStateBase
+{
+ /** @private */
+ public static TIME_STREAM_INDEX:number /*uint*/ = 0;
+
+ /** @private */
+ public static TIME_CONSTANT_INDEX:number /*uint*/ = 1;
+
+ private _particleTimeNode:ParticleTimeNode;
+
+ constructor(animator:ParticleAnimator, particleTimeNode:ParticleTimeNode)
+ {
+ super(animator, particleTimeNode, true);
+
+ this._particleTimeNode = particleTimeNode;
+ }
+
+ public setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)
+ {
+ animationSubGeometry.activateVertexBuffer(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleTimeState.TIME_STREAM_INDEX), this._particleTimeNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_4);
+
+ var particleTime:number = this._pTime/1000;
+ animationRegisterCache.setVertexConst(animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleTimeState.TIME_CONSTANT_INDEX), particleTime, particleTime, particleTime, particleTime);
+ }
+
+}
+
+export = ParticleTimeState;
\ No newline at end of file
diff --git a/lib/animators/states/ParticleUVState.js b/lib/animators/states/ParticleUVState.js
new file mode 100755
index 000000000..3c9d8b8f5
--- /dev/null
+++ b/lib/animators/states/ParticleUVState.js
@@ -0,0 +1,30 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+/**
+ * ...
+ */
+var ParticleUVState = (function (_super) {
+ __extends(ParticleUVState, _super);
+ function ParticleUVState(animator, particleUVNode) {
+ _super.call(this, animator, particleUVNode);
+ this._particleUVNode = particleUVNode;
+ }
+ ParticleUVState.prototype.setRenderState = function (stage, renderable, animationSubGeometry, animationRegisterCache, camera) {
+ if (animationRegisterCache.needUVAnimation) {
+ var index = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleUVState.UV_INDEX);
+ var data = this._particleUVNode._iUvData;
+ animationRegisterCache.setVertexConst(index, data.x, data.y);
+ }
+ };
+ /** @private */
+ ParticleUVState.UV_INDEX = 0;
+ return ParticleUVState;
+})(ParticleStateBase);
+module.exports = ParticleUVState;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9zdGF0ZXMvcGFydGljbGV1dnN0YXRlLnRzIl0sIm5hbWVzIjpbIlBhcnRpY2xlVVZTdGF0ZSIsIlBhcnRpY2xlVVZTdGF0ZS5jb25zdHJ1Y3RvciIsIlBhcnRpY2xlVVZTdGF0ZS5zZXRSZW5kZXJTdGF0ZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBVUEsSUFBTyxpQkFBaUIsV0FBYywwREFBMEQsQ0FBQyxDQUFDO0FBRWxHLEFBR0E7O0dBREc7SUFDRyxlQUFlO0lBQVNBLFVBQXhCQSxlQUFlQSxVQUEwQkE7SUFPOUNBLFNBUEtBLGVBQWVBLENBT1JBLFFBQXlCQSxFQUFFQSxjQUE2QkE7UUFFbkVDLGtCQUFNQSxRQUFRQSxFQUFFQSxjQUFjQSxDQUFDQSxDQUFDQTtRQUVoQ0EsSUFBSUEsQ0FBQ0EsZUFBZUEsR0FBR0EsY0FBY0EsQ0FBQ0E7SUFDdkNBLENBQUNBO0lBRU1ELHdDQUFjQSxHQUFyQkEsVUFBc0JBLEtBQVdBLEVBQUVBLFVBQXlCQSxFQUFFQSxvQkFBeUNBLEVBQUVBLHNCQUE2Q0EsRUFBRUEsTUFBYUE7UUFFcEtFLEVBQUVBLENBQUNBLENBQUNBLHNCQUFzQkEsQ0FBQ0EsZUFBZUEsQ0FBQ0EsQ0FBQ0EsQ0FBQ0E7WUFDNUNBLElBQUlBLEtBQUtBLEdBQWtCQSxzQkFBc0JBLENBQUNBLGdCQUFnQkEsQ0FBQ0EsSUFBSUEsQ0FBQ0EsZUFBZUEsRUFBRUEsZUFBZUEsQ0FBQ0EsUUFBUUEsQ0FBQ0EsQ0FBQ0E7WUFDbkhBLElBQUlBLElBQUlBLEdBQVlBLElBQUlBLENBQUNBLGVBQWVBLENBQUNBLFFBQVFBLENBQUNBO1lBQ2xEQSxzQkFBc0JBLENBQUNBLGNBQWNBLENBQUNBLEtBQUtBLEVBQUVBLElBQUlBLENBQUNBLENBQUNBLEVBQUVBLElBQUlBLENBQUNBLENBQUNBLENBQUNBLENBQUNBO1FBQzlEQSxDQUFDQTtJQUNGQSxDQUFDQTtJQW5CREYsZUFBZUE7SUFDREEsd0JBQVFBLEdBQW1CQSxDQUFDQSxDQUFDQTtJQW9CNUNBLHNCQUFDQTtBQUFEQSxDQXZCQSxBQXVCQ0EsRUF2QjZCLGlCQUFpQixFQXVCOUM7QUFFRCxBQUF5QixpQkFBaEIsZUFBZSxDQUFDIiwiZmlsZSI6ImFuaW1hdG9ycy9zdGF0ZXMvUGFydGljbGVVVlN0YXRlLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2JiYXRlbWFuL1dlYnN0b3JtUHJvamVjdHMvYXdheWpzLXJlbmRlcmVyZ2wvIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFZlY3RvcjNEXHRcdFx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvY29yZS9nZW9tL1ZlY3RvcjNEXCIpO1xuaW1wb3J0IENhbWVyYVx0XHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLWNvcmUvbGliL2VudGl0aWVzL0NhbWVyYVwiKTtcblxuaW1wb3J0IEFuaW1hdGlvblJlZ2lzdGVyQ2FjaGVcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvYW5pbWF0b3JzL2RhdGEvQW5pbWF0aW9uUmVnaXN0ZXJDYWNoZVwiKTtcbmltcG9ydCBTdGFnZVx0XHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2NvcmUvYmFzZS9TdGFnZVwiKTtcbmltcG9ydCBSZW5kZXJhYmxlQmFzZVx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvY29yZS9wb29sL1JlbmRlcmFibGVCYXNlXCIpO1xuXG5pbXBvcnQgUGFydGljbGVBbmltYXRvclx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL1BhcnRpY2xlQW5pbWF0b3JcIik7XG5pbXBvcnQgQW5pbWF0aW9uU3ViR2VvbWV0cnlcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvZGF0YS9BbmltYXRpb25TdWJHZW9tZXRyeVwiKTtcbmltcG9ydCBQYXJ0aWNsZVVWTm9kZVx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL25vZGVzL1BhcnRpY2xlVVZOb2RlXCIpO1xuaW1wb3J0IFBhcnRpY2xlU3RhdGVCYXNlXHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL3N0YXRlcy9QYXJ0aWNsZVN0YXRlQmFzZVwiKTtcblxuLyoqXG4gKiAuLi5cbiAqL1xuY2xhc3MgUGFydGljbGVVVlN0YXRlIGV4dGVuZHMgUGFydGljbGVTdGF0ZUJhc2Vcbntcblx0LyoqIEBwcml2YXRlICovXG5cdHB1YmxpYyBzdGF0aWMgVVZfSU5ERVg6bnVtYmVyIC8qdWludCovID0gMDtcblxuXHRwcml2YXRlIF9wYXJ0aWNsZVVWTm9kZTpQYXJ0aWNsZVVWTm9kZTtcblxuXHRjb25zdHJ1Y3RvcihhbmltYXRvcjpQYXJ0aWNsZUFuaW1hdG9yLCBwYXJ0aWNsZVVWTm9kZTpQYXJ0aWNsZVVWTm9kZSlcblx0e1xuXHRcdHN1cGVyKGFuaW1hdG9yLCBwYXJ0aWNsZVVWTm9kZSk7XG5cblx0XHR0aGlzLl9wYXJ0aWNsZVVWTm9kZSA9IHBhcnRpY2xlVVZOb2RlO1xuXHR9XG5cblx0cHVibGljIHNldFJlbmRlclN0YXRlKHN0YWdlOlN0YWdlLCByZW5kZXJhYmxlOlJlbmRlcmFibGVCYXNlLCBhbmltYXRpb25TdWJHZW9tZXRyeTpBbmltYXRpb25TdWJHZW9tZXRyeSwgYW5pbWF0aW9uUmVnaXN0ZXJDYWNoZTpBbmltYXRpb25SZWdpc3RlckNhY2hlLCBjYW1lcmE6Q2FtZXJhKVxuXHR7XG5cdFx0aWYgKGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGUubmVlZFVWQW5pbWF0aW9uKSB7XG5cdFx0XHR2YXIgaW5kZXg6bnVtYmVyIC8qaW50Ki8gPSBhbmltYXRpb25SZWdpc3RlckNhY2hlLmdldFJlZ2lzdGVySW5kZXgodGhpcy5fcEFuaW1hdGlvbk5vZGUsIFBhcnRpY2xlVVZTdGF0ZS5VVl9JTkRFWCk7XG5cdFx0XHR2YXIgZGF0YTpWZWN0b3IzRCA9IHRoaXMuX3BhcnRpY2xlVVZOb2RlLl9pVXZEYXRhO1xuXHRcdFx0YW5pbWF0aW9uUmVnaXN0ZXJDYWNoZS5zZXRWZXJ0ZXhDb25zdChpbmRleCwgZGF0YS54LCBkYXRhLnkpO1xuXHRcdH1cblx0fVxuXG59XG5cbmV4cG9ydCA9IFBhcnRpY2xlVVZTdGF0ZTsiXX0=
\ No newline at end of file
diff --git a/lib/animators/states/ParticleUVState.ts b/lib/animators/states/ParticleUVState.ts
new file mode 100644
index 000000000..d66f7469f
--- /dev/null
+++ b/lib/animators/states/ParticleUVState.ts
@@ -0,0 +1,41 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+
+import ParticleAnimator = require("awayjs-renderergl/lib/animators/ParticleAnimator");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticleUVNode = require("awayjs-renderergl/lib/animators/nodes/ParticleUVNode");
+import ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+
+/**
+ * ...
+ */
+class ParticleUVState extends ParticleStateBase
+{
+ /** @private */
+ public static UV_INDEX:number /*uint*/ = 0;
+
+ private _particleUVNode:ParticleUVNode;
+
+ constructor(animator:ParticleAnimator, particleUVNode:ParticleUVNode)
+ {
+ super(animator, particleUVNode);
+
+ this._particleUVNode = particleUVNode;
+ }
+
+ public setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)
+ {
+ if (animationRegisterCache.needUVAnimation) {
+ var index:number /*int*/ = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleUVState.UV_INDEX);
+ var data:Vector3D = this._particleUVNode._iUvData;
+ animationRegisterCache.setVertexConst(index, data.x, data.y);
+ }
+ }
+
+}
+
+export = ParticleUVState;
\ No newline at end of file
diff --git a/lib/animators/states/ParticleVelocityState.js b/lib/animators/states/ParticleVelocityState.js
new file mode 100755
index 000000000..85016161e
--- /dev/null
+++ b/lib/animators/states/ParticleVelocityState.js
@@ -0,0 +1,58 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+var ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+var ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+/**
+ * ...
+ */
+var ParticleVelocityState = (function (_super) {
+ __extends(ParticleVelocityState, _super);
+ function ParticleVelocityState(animator, particleVelocityNode) {
+ _super.call(this, animator, particleVelocityNode);
+ this._particleVelocityNode = particleVelocityNode;
+ this._velocity = this._particleVelocityNode._iVelocity;
+ }
+ Object.defineProperty(ParticleVelocityState.prototype, "velocity", {
+ /**
+ * Defines the default velocity vector of the state, used when in global mode.
+ */
+ get: function () {
+ return this._velocity;
+ },
+ set: function (value) {
+ this._velocity = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ *
+ */
+ ParticleVelocityState.prototype.getVelocities = function () {
+ return this._pDynamicProperties;
+ };
+ ParticleVelocityState.prototype.setVelocities = function (value) {
+ this._pDynamicProperties = value;
+ this._pDynamicPropertiesDirty = new Object();
+ };
+ ParticleVelocityState.prototype.setRenderState = function (stage, renderable, animationSubGeometry, animationRegisterCache, camera) {
+ if (this._particleVelocityNode.mode == ParticlePropertiesMode.LOCAL_DYNAMIC && !this._pDynamicPropertiesDirty[animationSubGeometry._iUniqueId])
+ this._pUpdateDynamicProperties(animationSubGeometry);
+ var index = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleVelocityState.VELOCITY_INDEX);
+ if (this._particleVelocityNode.mode == ParticlePropertiesMode.GLOBAL)
+ animationRegisterCache.setVertexConst(index, this._velocity.x, this._velocity.y, this._velocity.z);
+ else
+ animationSubGeometry.activateVertexBuffer(index, this._particleVelocityNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ };
+ /** @private */
+ ParticleVelocityState.VELOCITY_INDEX = 0;
+ return ParticleVelocityState;
+})(ParticleStateBase);
+module.exports = ParticleVelocityState;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9zdGF0ZXMvcGFydGljbGV2ZWxvY2l0eXN0YXRlLnRzIl0sIm5hbWVzIjpbIlBhcnRpY2xlVmVsb2NpdHlTdGF0ZSIsIlBhcnRpY2xlVmVsb2NpdHlTdGF0ZS5jb25zdHJ1Y3RvciIsIlBhcnRpY2xlVmVsb2NpdHlTdGF0ZS52ZWxvY2l0eSIsIlBhcnRpY2xlVmVsb2NpdHlTdGF0ZS5nZXRWZWxvY2l0aWVzIiwiUGFydGljbGVWZWxvY2l0eVN0YXRlLnNldFZlbG9jaXRpZXMiLCJQYXJ0aWNsZVZlbG9jaXR5U3RhdGUuc2V0UmVuZGVyU3RhdGUiXSwibWFwcGluZ3MiOiI7Ozs7OztBQU1BLElBQU8sMkJBQTJCLFdBQVksNkRBQTZELENBQUMsQ0FBQztBQUk3RyxJQUFPLHNCQUFzQixXQUFhLDZEQUE2RCxDQUFDLENBQUM7QUFFekcsSUFBTyxpQkFBaUIsV0FBYywwREFBMEQsQ0FBQyxDQUFDO0FBRWxHLEFBR0E7O0dBREc7SUFDRyxxQkFBcUI7SUFBU0EsVUFBOUJBLHFCQUFxQkEsVUFBMEJBO0lBb0NwREEsU0FwQ0tBLHFCQUFxQkEsQ0FvQ2RBLFFBQXlCQSxFQUFFQSxvQkFBeUNBO1FBRS9FQyxrQkFBTUEsUUFBUUEsRUFBRUEsb0JBQW9CQSxDQUFDQSxDQUFDQTtRQUV0Q0EsSUFBSUEsQ0FBQ0EscUJBQXFCQSxHQUFHQSxvQkFBb0JBLENBQUNBO1FBQ2xEQSxJQUFJQSxDQUFDQSxTQUFTQSxHQUFHQSxJQUFJQSxDQUFDQSxxQkFBcUJBLENBQUNBLFVBQVVBLENBQUNBO0lBQ3hEQSxDQUFDQTtJQS9CREQsc0JBQVdBLDJDQUFRQTtRQUhuQkE7O1dBRUdBO2FBQ0hBO1lBRUNFLE1BQU1BLENBQUNBLElBQUlBLENBQUNBLFNBQVNBLENBQUNBO1FBQ3ZCQSxDQUFDQTthQUVERixVQUFvQkEsS0FBY0E7WUFFakNFLElBQUlBLENBQUNBLFNBQVNBLEdBQUdBLEtBQUtBLENBQUNBO1FBQ3hCQSxDQUFDQTs7O09BTEFGO0lBT0RBOztPQUVHQTtJQUNJQSw2Q0FBYUEsR0FBcEJBO1FBRUNHLE1BQU1BLENBQUNBLElBQUlBLENBQUNBLG1CQUFtQkEsQ0FBQ0E7SUFDakNBLENBQUNBO0lBRU1ILDZDQUFhQSxHQUFwQkEsVUFBcUJBLEtBQXFCQTtRQUV6Q0ksSUFBSUEsQ0FBQ0EsbUJBQW1CQSxHQUFHQSxLQUFLQSxDQUFDQTtRQUVqQ0EsSUFBSUEsQ0FBQ0Esd0JBQXdCQSxHQUFHQSxJQUFJQSxNQUFNQSxFQUFFQSxDQUFDQTtJQUM5Q0EsQ0FBQ0E7SUFVTUosOENBQWNBLEdBQXJCQSxVQUFzQkEsS0FBV0EsRUFBRUEsVUFBeUJBLEVBQUVBLG9CQUF5Q0EsRUFBRUEsc0JBQTZDQSxFQUFFQSxNQUFhQTtRQUVwS0ssRUFBRUEsQ0FBQ0EsQ0FBQ0EsSUFBSUEsQ0FBQ0EscUJBQXFCQSxDQUFDQSxJQUFJQSxJQUFJQSxzQkFBc0JBLENBQUNBLGFBQWFBLElBQUlBLENBQUNBLElBQUlBLENBQUNBLHdCQUF3QkEsQ0FBQ0Esb0JBQW9CQSxDQUFDQSxVQUFVQSxDQUFDQSxDQUFDQTtZQUM5SUEsSUFBSUEsQ0FBQ0EseUJBQXlCQSxDQUFDQSxvQkFBb0JBLENBQUNBLENBQUNBO1FBRXREQSxJQUFJQSxLQUFLQSxHQUFrQkEsc0JBQXNCQSxDQUFDQSxnQkFBZ0JBLENBQUNBLElBQUlBLENBQUNBLGVBQWVBLEVBQUVBLHFCQUFxQkEsQ0FBQ0EsY0FBY0EsQ0FBQ0EsQ0FBQ0E7UUFFL0hBLEVBQUVBLENBQUNBLENBQUNBLElBQUlBLENBQUNBLHFCQUFxQkEsQ0FBQ0EsSUFBSUEsSUFBSUEsc0JBQXNCQSxDQUFDQSxNQUFNQSxDQUFDQTtZQUNwRUEsc0JBQXNCQSxDQUFDQSxjQUFjQSxDQUFDQSxLQUFLQSxFQUFFQSxJQUFJQSxDQUFDQSxTQUFTQSxDQUFDQSxDQUFDQSxFQUFFQSxJQUFJQSxDQUFDQSxTQUFTQSxDQUFDQSxDQUFDQSxFQUFFQSxJQUFJQSxDQUFDQSxTQUFTQSxDQUFDQSxDQUFDQSxDQUFDQSxDQUFDQTtRQUNwR0EsSUFBSUE7WUFDSEEsb0JBQW9CQSxDQUFDQSxvQkFBb0JBLENBQUNBLEtBQUtBLEVBQUVBLElBQUlBLENBQUNBLHFCQUFxQkEsQ0FBQ0EsWUFBWUEsRUFBRUEsS0FBS0EsRUFBRUEsMkJBQTJCQSxDQUFDQSxPQUFPQSxDQUFDQSxDQUFDQTtJQUN4SUEsQ0FBQ0E7SUFyRERMLGVBQWVBO0lBQ0RBLG9DQUFjQSxHQUFrQkEsQ0FBQ0EsQ0FBQ0E7SUFxRGpEQSw0QkFBQ0E7QUFBREEsQ0F4REEsQUF3RENBLEVBeERtQyxpQkFBaUIsRUF3RHBEO0FBRUQsQUFBK0IsaUJBQXRCLHFCQUFxQixDQUFDIiwiZmlsZSI6ImFuaW1hdG9ycy9zdGF0ZXMvUGFydGljbGVWZWxvY2l0eVN0YXRlLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2JiYXRlbWFuL1dlYnN0b3JtUHJvamVjdHMvYXdheWpzLXJlbmRlcmVyZ2wvIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFZlY3RvcjNEXHRcdFx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvY29yZS9nZW9tL1ZlY3RvcjNEXCIpO1xuaW1wb3J0IENhbWVyYVx0XHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLWNvcmUvbGliL2VudGl0aWVzL0NhbWVyYVwiKTtcblxuaW1wb3J0IEFuaW1hdGlvblJlZ2lzdGVyQ2FjaGVcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvYW5pbWF0b3JzL2RhdGEvQW5pbWF0aW9uUmVnaXN0ZXJDYWNoZVwiKTtcbmltcG9ydCBTdGFnZVx0XHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2NvcmUvYmFzZS9TdGFnZVwiKTtcbmltcG9ydCBSZW5kZXJhYmxlQmFzZVx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvY29yZS9wb29sL1JlbmRlcmFibGVCYXNlXCIpO1xuaW1wb3J0IENvbnRleHRHTFZlcnRleEJ1ZmZlckZvcm1hdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvY29yZS9zdGFnZWdsL0NvbnRleHRHTFZlcnRleEJ1ZmZlckZvcm1hdFwiKTtcblxuaW1wb3J0IFBhcnRpY2xlQW5pbWF0b3JcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXJlbmRlcmVyZ2wvbGliL2FuaW1hdG9ycy9QYXJ0aWNsZUFuaW1hdG9yXCIpO1xuaW1wb3J0IEFuaW1hdGlvblN1Ykdlb21ldHJ5XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL2RhdGEvQW5pbWF0aW9uU3ViR2VvbWV0cnlcIik7XG5pbXBvcnQgUGFydGljbGVQcm9wZXJ0aWVzTW9kZVx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvZGF0YS9QYXJ0aWNsZVByb3BlcnRpZXNNb2RlXCIpO1xuaW1wb3J0IFBhcnRpY2xlVmVsb2NpdHlOb2RlXHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL25vZGVzL1BhcnRpY2xlVmVsb2NpdHlOb2RlXCIpO1xuaW1wb3J0IFBhcnRpY2xlU3RhdGVCYXNlXHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL3N0YXRlcy9QYXJ0aWNsZVN0YXRlQmFzZVwiKTtcblxuLyoqXG4gKiAuLi5cbiAqL1xuY2xhc3MgUGFydGljbGVWZWxvY2l0eVN0YXRlIGV4dGVuZHMgUGFydGljbGVTdGF0ZUJhc2Vcbntcblx0LyoqIEBwcml2YXRlICovXG5cdHB1YmxpYyBzdGF0aWMgVkVMT0NJVFlfSU5ERVg6bnVtYmVyIC8qaW50Ki8gPSAwO1xuXG5cdHByaXZhdGUgX3BhcnRpY2xlVmVsb2NpdHlOb2RlOlBhcnRpY2xlVmVsb2NpdHlOb2RlO1xuXHRwcml2YXRlIF92ZWxvY2l0eTpWZWN0b3IzRDtcblxuXHQvKipcblx0ICogRGVmaW5lcyB0aGUgZGVmYXVsdCB2ZWxvY2l0eSB2ZWN0b3Igb2YgdGhlIHN0YXRlLCB1c2VkIHdoZW4gaW4gZ2xvYmFsIG1vZGUuXG5cdCAqL1xuXHRwdWJsaWMgZ2V0IHZlbG9jaXR5KCk6VmVjdG9yM0Rcblx0e1xuXHRcdHJldHVybiB0aGlzLl92ZWxvY2l0eTtcblx0fVxuXG5cdHB1YmxpYyBzZXQgdmVsb2NpdHkodmFsdWU6VmVjdG9yM0QpXG5cdHtcblx0XHR0aGlzLl92ZWxvY2l0eSA9IHZhbHVlO1xuXHR9XG5cblx0LyoqXG5cdCAqXG5cdCAqL1xuXHRwdWJsaWMgZ2V0VmVsb2NpdGllcygpOkFycmF5PFZlY3RvcjNEPlxuXHR7XG5cdFx0cmV0dXJuIHRoaXMuX3BEeW5hbWljUHJvcGVydGllcztcblx0fVxuXG5cdHB1YmxpYyBzZXRWZWxvY2l0aWVzKHZhbHVlOkFycmF5PFZlY3RvcjNEPilcblx0e1xuXHRcdHRoaXMuX3BEeW5hbWljUHJvcGVydGllcyA9IHZhbHVlO1xuXG5cdFx0dGhpcy5fcER5bmFtaWNQcm9wZXJ0aWVzRGlydHkgPSBuZXcgT2JqZWN0KCk7XG5cdH1cblxuXHRjb25zdHJ1Y3RvcihhbmltYXRvcjpQYXJ0aWNsZUFuaW1hdG9yLCBwYXJ0aWNsZVZlbG9jaXR5Tm9kZTpQYXJ0aWNsZVZlbG9jaXR5Tm9kZSlcblx0e1xuXHRcdHN1cGVyKGFuaW1hdG9yLCBwYXJ0aWNsZVZlbG9jaXR5Tm9kZSk7XG5cblx0XHR0aGlzLl9wYXJ0aWNsZVZlbG9jaXR5Tm9kZSA9IHBhcnRpY2xlVmVsb2NpdHlOb2RlO1xuXHRcdHRoaXMuX3ZlbG9jaXR5ID0gdGhpcy5fcGFydGljbGVWZWxvY2l0eU5vZGUuX2lWZWxvY2l0eTtcblx0fVxuXG5cdHB1YmxpYyBzZXRSZW5kZXJTdGF0ZShzdGFnZTpTdGFnZSwgcmVuZGVyYWJsZTpSZW5kZXJhYmxlQmFzZSwgYW5pbWF0aW9uU3ViR2VvbWV0cnk6QW5pbWF0aW9uU3ViR2VvbWV0cnksIGFuaW1hdGlvblJlZ2lzdGVyQ2FjaGU6QW5pbWF0aW9uUmVnaXN0ZXJDYWNoZSwgY2FtZXJhOkNhbWVyYSlcblx0e1xuXHRcdGlmICh0aGlzLl9wYXJ0aWNsZVZlbG9jaXR5Tm9kZS5tb2RlID09IFBhcnRpY2xlUHJvcGVydGllc01vZGUuTE9DQUxfRFlOQU1JQyAmJiAhdGhpcy5fcER5bmFtaWNQcm9wZXJ0aWVzRGlydHlbYW5pbWF0aW9uU3ViR2VvbWV0cnkuX2lVbmlxdWVJZF0pXG5cdFx0XHR0aGlzLl9wVXBkYXRlRHluYW1pY1Byb3BlcnRpZXMoYW5pbWF0aW9uU3ViR2VvbWV0cnkpO1xuXG5cdFx0dmFyIGluZGV4Om51bWJlciAvKmludCovID0gYW5pbWF0aW9uUmVnaXN0ZXJDYWNoZS5nZXRSZWdpc3RlckluZGV4KHRoaXMuX3BBbmltYXRpb25Ob2RlLCBQYXJ0aWNsZVZlbG9jaXR5U3RhdGUuVkVMT0NJVFlfSU5ERVgpO1xuXG5cdFx0aWYgKHRoaXMuX3BhcnRpY2xlVmVsb2NpdHlOb2RlLm1vZGUgPT0gUGFydGljbGVQcm9wZXJ0aWVzTW9kZS5HTE9CQUwpXG5cdFx0XHRhbmltYXRpb25SZWdpc3RlckNhY2hlLnNldFZlcnRleENvbnN0KGluZGV4LCB0aGlzLl92ZWxvY2l0eS54LCB0aGlzLl92ZWxvY2l0eS55LCB0aGlzLl92ZWxvY2l0eS56KTtcblx0XHRlbHNlXG5cdFx0XHRhbmltYXRpb25TdWJHZW9tZXRyeS5hY3RpdmF0ZVZlcnRleEJ1ZmZlcihpbmRleCwgdGhpcy5fcGFydGljbGVWZWxvY2l0eU5vZGUuX2lEYXRhT2Zmc2V0LCBzdGFnZSwgQ29udGV4dEdMVmVydGV4QnVmZmVyRm9ybWF0LkZMT0FUXzMpO1xuXHR9XG59XG5cbmV4cG9ydCA9IFBhcnRpY2xlVmVsb2NpdHlTdGF0ZTsiXX0=
\ No newline at end of file
diff --git a/lib/animators/states/ParticleVelocityState.ts b/lib/animators/states/ParticleVelocityState.ts
new file mode 100644
index 000000000..1aa8bb43c
--- /dev/null
+++ b/lib/animators/states/ParticleVelocityState.ts
@@ -0,0 +1,76 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import AnimationRegisterCache = require("awayjs-stagegl/lib/animators/data/AnimationRegisterCache");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import ContextGLVertexBufferFormat = require("awayjs-stagegl/lib/core/stagegl/ContextGLVertexBufferFormat");
+
+import ParticleAnimator = require("awayjs-renderergl/lib/animators/ParticleAnimator");
+import AnimationSubGeometry = require("awayjs-renderergl/lib/animators/data/AnimationSubGeometry");
+import ParticlePropertiesMode = require("awayjs-renderergl/lib/animators/data/ParticlePropertiesMode");
+import ParticleVelocityNode = require("awayjs-renderergl/lib/animators/nodes/ParticleVelocityNode");
+import ParticleStateBase = require("awayjs-renderergl/lib/animators/states/ParticleStateBase");
+
+/**
+ * ...
+ */
+class ParticleVelocityState extends ParticleStateBase
+{
+ /** @private */
+ public static VELOCITY_INDEX:number /*int*/ = 0;
+
+ private _particleVelocityNode:ParticleVelocityNode;
+ private _velocity:Vector3D;
+
+ /**
+ * Defines the default velocity vector of the state, used when in global mode.
+ */
+ public get velocity():Vector3D
+ {
+ return this._velocity;
+ }
+
+ public set velocity(value:Vector3D)
+ {
+ this._velocity = value;
+ }
+
+ /**
+ *
+ */
+ public getVelocities():Array
+ {
+ return this._pDynamicProperties;
+ }
+
+ public setVelocities(value:Array)
+ {
+ this._pDynamicProperties = value;
+
+ this._pDynamicPropertiesDirty = new Object();
+ }
+
+ constructor(animator:ParticleAnimator, particleVelocityNode:ParticleVelocityNode)
+ {
+ super(animator, particleVelocityNode);
+
+ this._particleVelocityNode = particleVelocityNode;
+ this._velocity = this._particleVelocityNode._iVelocity;
+ }
+
+ public setRenderState(stage:Stage, renderable:RenderableBase, animationSubGeometry:AnimationSubGeometry, animationRegisterCache:AnimationRegisterCache, camera:Camera)
+ {
+ if (this._particleVelocityNode.mode == ParticlePropertiesMode.LOCAL_DYNAMIC && !this._pDynamicPropertiesDirty[animationSubGeometry._iUniqueId])
+ this._pUpdateDynamicProperties(animationSubGeometry);
+
+ var index:number /*int*/ = animationRegisterCache.getRegisterIndex(this._pAnimationNode, ParticleVelocityState.VELOCITY_INDEX);
+
+ if (this._particleVelocityNode.mode == ParticlePropertiesMode.GLOBAL)
+ animationRegisterCache.setVertexConst(index, this._velocity.x, this._velocity.y, this._velocity.z);
+ else
+ animationSubGeometry.activateVertexBuffer(index, this._particleVelocityNode._iDataOffset, stage, ContextGLVertexBufferFormat.FLOAT_3);
+ }
+}
+
+export = ParticleVelocityState;
\ No newline at end of file
diff --git a/lib/animators/states/SkeletonBinaryLERPState.js b/lib/animators/states/SkeletonBinaryLERPState.js
new file mode 100755
index 000000000..a77755d1d
--- /dev/null
+++ b/lib/animators/states/SkeletonBinaryLERPState.js
@@ -0,0 +1,117 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var JointPose = require("awayjs-renderergl/lib/animators/data/JointPose");
+var SkeletonPose = require("awayjs-renderergl/lib/animators/data/SkeletonPose");
+var AnimationStateBase = require("awayjs-renderergl/lib/animators/states/AnimationStateBase");
+/**
+ *
+ */
+var SkeletonBinaryLERPState = (function (_super) {
+ __extends(SkeletonBinaryLERPState, _super);
+ function SkeletonBinaryLERPState(animator, skeletonAnimationNode) {
+ _super.call(this, animator, skeletonAnimationNode);
+ this._blendWeight = 0;
+ this._skeletonPose = new SkeletonPose();
+ this._skeletonPoseDirty = true;
+ this._skeletonAnimationNode = skeletonAnimationNode;
+ this._inputA = animator.getAnimationState(this._skeletonAnimationNode.inputA);
+ this._inputB = animator.getAnimationState(this._skeletonAnimationNode.inputB);
+ }
+ Object.defineProperty(SkeletonBinaryLERPState.prototype, "blendWeight", {
+ /**
+ * Defines a fractional value between 0 and 1 representing the blending ratio between inputA (0) and inputB (1),
+ * used to produce the skeleton pose output.
+ *
+ * @see inputA
+ * @see inputB
+ */
+ get: function () {
+ return this._blendWeight;
+ },
+ set: function (value) {
+ this._blendWeight = value;
+ this._pPositionDeltaDirty = true;
+ this._skeletonPoseDirty = true;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ SkeletonBinaryLERPState.prototype.phase = function (value) {
+ this._skeletonPoseDirty = true;
+ this._pPositionDeltaDirty = true;
+ this._inputA.phase(value);
+ this._inputB.phase(value);
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonBinaryLERPState.prototype._pUpdateTime = function (time /*int*/) {
+ this._skeletonPoseDirty = true;
+ this._inputA.update(time);
+ this._inputB.update(time);
+ _super.prototype._pUpdateTime.call(this, time);
+ };
+ /**
+ * Returns the current skeleton pose of the animation in the clip based on the internal playhead position.
+ */
+ SkeletonBinaryLERPState.prototype.getSkeletonPose = function (skeleton) {
+ if (this._skeletonPoseDirty)
+ this.updateSkeletonPose(skeleton);
+ return this._skeletonPose;
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonBinaryLERPState.prototype._pUpdatePositionDelta = function () {
+ this._pPositionDeltaDirty = false;
+ var deltA = this._inputA.positionDelta;
+ var deltB = this._inputB.positionDelta;
+ this._pRootDelta.x = deltA.x + this._blendWeight * (deltB.x - deltA.x);
+ this._pRootDelta.y = deltA.y + this._blendWeight * (deltB.y - deltA.y);
+ this._pRootDelta.z = deltA.z + this._blendWeight * (deltB.z - deltA.z);
+ };
+ /**
+ * Updates the output skeleton pose of the node based on the blendWeight value between input nodes.
+ *
+ * @param skeleton The skeleton used by the animator requesting the ouput pose.
+ */
+ SkeletonBinaryLERPState.prototype.updateSkeletonPose = function (skeleton) {
+ this._skeletonPoseDirty = false;
+ var endPose;
+ var endPoses = this._skeletonPose.jointPoses;
+ var poses1 = this._inputA.getSkeletonPose(skeleton).jointPoses;
+ var poses2 = this._inputB.getSkeletonPose(skeleton).jointPoses;
+ var pose1, pose2;
+ var p1, p2;
+ var tr;
+ var numJoints = skeleton.numJoints;
+ // :s
+ if (endPoses.length != numJoints)
+ endPoses.length = numJoints;
+ for (var i = 0; i < numJoints; ++i) {
+ endPose = endPoses[i];
+ if (endPose == null)
+ endPose = endPoses[i] = new JointPose();
+ pose1 = poses1[i];
+ pose2 = poses2[i];
+ p1 = pose1.translation;
+ p2 = pose2.translation;
+ endPose.orientation.lerp(pose1.orientation, pose2.orientation, this._blendWeight);
+ tr = endPose.translation;
+ tr.x = p1.x + this._blendWeight * (p2.x - p1.x);
+ tr.y = p1.y + this._blendWeight * (p2.y - p1.y);
+ tr.z = p1.z + this._blendWeight * (p2.z - p1.z);
+ }
+ };
+ return SkeletonBinaryLERPState;
+})(AnimationStateBase);
+module.exports = SkeletonBinaryLERPState;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/states/skeletonbinarylerpstate.ts"],"names":["SkeletonBinaryLERPState","SkeletonBinaryLERPState.constructor","SkeletonBinaryLERPState.blendWeight","SkeletonBinaryLERPState.phase","SkeletonBinaryLERPState._pUpdateTime","SkeletonBinaryLERPState.getSkeletonPose","SkeletonBinaryLERPState._pUpdatePositionDelta","SkeletonBinaryLERPState.updateSkeletonPose"],"mappings":"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","file":"animators/states/SkeletonBinaryLERPState.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\n\nimport JointPose\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/JointPose\");\nimport Skeleton\t\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/Skeleton\");\nimport SkeletonPose\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/SkeletonPose\");\nimport SkeletonBinaryLERPNode\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/SkeletonBinaryLERPNode\");\nimport AnimationStateBase\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/AnimationStateBase\");\nimport ISkeletonAnimationState\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ISkeletonAnimationState\");\n\n/**\n *\n */\nclass SkeletonBinaryLERPState extends AnimationStateBase implements ISkeletonAnimationState\n{\n\tprivate _blendWeight:number = 0;\n\tprivate _skeletonAnimationNode:SkeletonBinaryLERPNode;\n\tprivate _skeletonPose:SkeletonPose = new SkeletonPose();\n\tprivate _skeletonPoseDirty:boolean = true;\n\tprivate _inputA:ISkeletonAnimationState;\n\tprivate _inputB:ISkeletonAnimationState;\n\n\t/**\n\t * Defines a fractional value between 0 and 1 representing the blending ratio between inputA (0) and inputB (1),\n\t * used to produce the skeleton pose output.\n\t *\n\t * @see inputA\n\t * @see inputB\n\t */\n\tpublic get blendWeight():number\n\t{\n\t\treturn this._blendWeight;\n\t}\n\n\tpublic set blendWeight(value:number)\n\t{\n\t\tthis._blendWeight = value;\n\n\t\tthis._pPositionDeltaDirty = true;\n\t\tthis._skeletonPoseDirty = true;\n\t}\n\n\tconstructor(animator:AnimatorBase, skeletonAnimationNode:SkeletonBinaryLERPNode)\n\t{\n\t\tsuper(animator, skeletonAnimationNode);\n\n\t\tthis._skeletonAnimationNode = skeletonAnimationNode;\n\n\t\tthis._inputA = <ISkeletonAnimationState> animator.getAnimationState(this._skeletonAnimationNode.inputA);\n\t\tthis._inputB = <ISkeletonAnimationState> animator.getAnimationState(this._skeletonAnimationNode.inputB);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic phase(value:number)\n\t{\n\t\tthis._skeletonPoseDirty = true;\n\n\t\tthis._pPositionDeltaDirty = true;\n\n\t\tthis._inputA.phase(value);\n\t\tthis._inputB.phase(value);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _pUpdateTime(time:number /*int*/)\n\t{\n\t\tthis._skeletonPoseDirty = true;\n\n\t\tthis._inputA.update(time);\n\t\tthis._inputB.update(time);\n\n\t\tsuper._pUpdateTime(time);\n\t}\n\n\t/**\n\t * Returns the current skeleton pose of the animation in the clip based on the internal playhead position.\n\t */\n\tpublic getSkeletonPose(skeleton:Skeleton):SkeletonPose\n\t{\n\t\tif (this._skeletonPoseDirty)\n\t\t\tthis.updateSkeletonPose(skeleton);\n\n\t\treturn this._skeletonPose;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _pUpdatePositionDelta()\n\t{\n\t\tthis._pPositionDeltaDirty = false;\n\n\t\tvar deltA:Vector3D = this._inputA.positionDelta;\n\t\tvar deltB:Vector3D = this._inputB.positionDelta;\n\n\t\tthis._pRootDelta.x = deltA.x + this._blendWeight*(deltB.x - deltA.x);\n\t\tthis._pRootDelta.y = deltA.y + this._blendWeight*(deltB.y - deltA.y);\n\t\tthis._pRootDelta.z = deltA.z + this._blendWeight*(deltB.z - deltA.z);\n\t}\n\n\t/**\n\t * Updates the output skeleton pose of the node based on the blendWeight value between input nodes.\n\t *\n\t * @param skeleton The skeleton used by the animator requesting the ouput pose.\n\t */\n\tprivate updateSkeletonPose(skeleton:Skeleton)\n\t{\n\t\tthis._skeletonPoseDirty = false;\n\n\t\tvar endPose:JointPose;\n\t\tvar endPoses:Array<JointPose> = this._skeletonPose.jointPoses;\n\t\tvar poses1:Array<JointPose> = this._inputA.getSkeletonPose(skeleton).jointPoses;\n\t\tvar poses2:Array<JointPose> = this._inputB.getSkeletonPose(skeleton).jointPoses;\n\t\tvar pose1:JointPose, pose2:JointPose;\n\t\tvar p1:Vector3D, p2:Vector3D;\n\t\tvar tr:Vector3D;\n\t\tvar numJoints:number /*uint*/ = skeleton.numJoints;\n\n\t\t// :s\n\t\tif (endPoses.length != numJoints)\n\t\t\tendPoses.length = numJoints;\n\n\t\tfor (var i:number /*uint*/ = 0; i < numJoints; ++i) {\n\t\t\tendPose = endPoses[i];\n\n\t\t\tif (endPose == null)\n\t\t\t\tendPose = endPoses[i] = new JointPose();\n\n\t\t\tpose1 = poses1[i];\n\t\t\tpose2 = poses2[i];\n\t\t\tp1 = pose1.translation;\n\t\t\tp2 = pose2.translation;\n\n\t\t\tendPose.orientation.lerp(pose1.orientation, pose2.orientation, this._blendWeight);\n\n\t\t\ttr = endPose.translation;\n\t\t\ttr.x = p1.x + this._blendWeight*(p2.x - p1.x);\n\t\t\ttr.y = p1.y + this._blendWeight*(p2.y - p1.y);\n\t\t\ttr.z = p1.z + this._blendWeight*(p2.z - p1.z);\n\t\t}\n\t}\n}\n\nexport = SkeletonBinaryLERPState;"]}
\ No newline at end of file
diff --git a/lib/animators/states/SkeletonBinaryLERPState.ts b/lib/animators/states/SkeletonBinaryLERPState.ts
new file mode 100644
index 000000000..5dee2247f
--- /dev/null
+++ b/lib/animators/states/SkeletonBinaryLERPState.ts
@@ -0,0 +1,149 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+
+import JointPose = require("awayjs-renderergl/lib/animators/data/JointPose");
+import Skeleton = require("awayjs-renderergl/lib/animators/data/Skeleton");
+import SkeletonPose = require("awayjs-renderergl/lib/animators/data/SkeletonPose");
+import SkeletonBinaryLERPNode = require("awayjs-renderergl/lib/animators/nodes/SkeletonBinaryLERPNode");
+import AnimationStateBase = require("awayjs-renderergl/lib/animators/states/AnimationStateBase");
+import ISkeletonAnimationState = require("awayjs-renderergl/lib/animators/states/ISkeletonAnimationState");
+
+/**
+ *
+ */
+class SkeletonBinaryLERPState extends AnimationStateBase implements ISkeletonAnimationState
+{
+ private _blendWeight:number = 0;
+ private _skeletonAnimationNode:SkeletonBinaryLERPNode;
+ private _skeletonPose:SkeletonPose = new SkeletonPose();
+ private _skeletonPoseDirty:boolean = true;
+ private _inputA:ISkeletonAnimationState;
+ private _inputB:ISkeletonAnimationState;
+
+ /**
+ * Defines a fractional value between 0 and 1 representing the blending ratio between inputA (0) and inputB (1),
+ * used to produce the skeleton pose output.
+ *
+ * @see inputA
+ * @see inputB
+ */
+ public get blendWeight():number
+ {
+ return this._blendWeight;
+ }
+
+ public set blendWeight(value:number)
+ {
+ this._blendWeight = value;
+
+ this._pPositionDeltaDirty = true;
+ this._skeletonPoseDirty = true;
+ }
+
+ constructor(animator:AnimatorBase, skeletonAnimationNode:SkeletonBinaryLERPNode)
+ {
+ super(animator, skeletonAnimationNode);
+
+ this._skeletonAnimationNode = skeletonAnimationNode;
+
+ this._inputA = animator.getAnimationState(this._skeletonAnimationNode.inputA);
+ this._inputB = animator.getAnimationState(this._skeletonAnimationNode.inputB);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public phase(value:number)
+ {
+ this._skeletonPoseDirty = true;
+
+ this._pPositionDeltaDirty = true;
+
+ this._inputA.phase(value);
+ this._inputB.phase(value);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pUpdateTime(time:number /*int*/)
+ {
+ this._skeletonPoseDirty = true;
+
+ this._inputA.update(time);
+ this._inputB.update(time);
+
+ super._pUpdateTime(time);
+ }
+
+ /**
+ * Returns the current skeleton pose of the animation in the clip based on the internal playhead position.
+ */
+ public getSkeletonPose(skeleton:Skeleton):SkeletonPose
+ {
+ if (this._skeletonPoseDirty)
+ this.updateSkeletonPose(skeleton);
+
+ return this._skeletonPose;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pUpdatePositionDelta()
+ {
+ this._pPositionDeltaDirty = false;
+
+ var deltA:Vector3D = this._inputA.positionDelta;
+ var deltB:Vector3D = this._inputB.positionDelta;
+
+ this._pRootDelta.x = deltA.x + this._blendWeight*(deltB.x - deltA.x);
+ this._pRootDelta.y = deltA.y + this._blendWeight*(deltB.y - deltA.y);
+ this._pRootDelta.z = deltA.z + this._blendWeight*(deltB.z - deltA.z);
+ }
+
+ /**
+ * Updates the output skeleton pose of the node based on the blendWeight value between input nodes.
+ *
+ * @param skeleton The skeleton used by the animator requesting the ouput pose.
+ */
+ private updateSkeletonPose(skeleton:Skeleton)
+ {
+ this._skeletonPoseDirty = false;
+
+ var endPose:JointPose;
+ var endPoses:Array = this._skeletonPose.jointPoses;
+ var poses1:Array = this._inputA.getSkeletonPose(skeleton).jointPoses;
+ var poses2:Array = this._inputB.getSkeletonPose(skeleton).jointPoses;
+ var pose1:JointPose, pose2:JointPose;
+ var p1:Vector3D, p2:Vector3D;
+ var tr:Vector3D;
+ var numJoints:number /*uint*/ = skeleton.numJoints;
+
+ // :s
+ if (endPoses.length != numJoints)
+ endPoses.length = numJoints;
+
+ for (var i:number /*uint*/ = 0; i < numJoints; ++i) {
+ endPose = endPoses[i];
+
+ if (endPose == null)
+ endPose = endPoses[i] = new JointPose();
+
+ pose1 = poses1[i];
+ pose2 = poses2[i];
+ p1 = pose1.translation;
+ p2 = pose2.translation;
+
+ endPose.orientation.lerp(pose1.orientation, pose2.orientation, this._blendWeight);
+
+ tr = endPose.translation;
+ tr.x = p1.x + this._blendWeight*(p2.x - p1.x);
+ tr.y = p1.y + this._blendWeight*(p2.y - p1.y);
+ tr.z = p1.z + this._blendWeight*(p2.z - p1.z);
+ }
+ }
+}
+
+export = SkeletonBinaryLERPState;
\ No newline at end of file
diff --git a/lib/animators/states/SkeletonClipState.js b/lib/animators/states/SkeletonClipState.js
new file mode 100755
index 000000000..958d9abbc
--- /dev/null
+++ b/lib/animators/states/SkeletonClipState.js
@@ -0,0 +1,162 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var JointPose = require("awayjs-renderergl/lib/animators/data/JointPose");
+var SkeletonPose = require("awayjs-renderergl/lib/animators/data/SkeletonPose");
+var AnimationClipState = require("awayjs-renderergl/lib/animators/states/AnimationClipState");
+/**
+ *
+ */
+var SkeletonClipState = (function (_super) {
+ __extends(SkeletonClipState, _super);
+ function SkeletonClipState(animator, skeletonClipNode) {
+ _super.call(this, animator, skeletonClipNode);
+ this._rootPos = new Vector3D();
+ this._skeletonPose = new SkeletonPose();
+ this._skeletonPoseDirty = true;
+ this._skeletonClipNode = skeletonClipNode;
+ this._frames = this._skeletonClipNode.frames;
+ }
+ Object.defineProperty(SkeletonClipState.prototype, "currentPose", {
+ /**
+ * Returns the current skeleton pose frame of animation in the clip based on the internal playhead position.
+ */
+ get: function () {
+ if (this._pFramesDirty)
+ this._pUpdateFrames();
+ return this._currentPose;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(SkeletonClipState.prototype, "nextPose", {
+ /**
+ * Returns the next skeleton pose frame of animation in the clip based on the internal playhead position.
+ */
+ get: function () {
+ if (this._pFramesDirty)
+ this._pUpdateFrames();
+ return this._nextPose;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * Returns the current skeleton pose of the animation in the clip based on the internal playhead position.
+ */
+ SkeletonClipState.prototype.getSkeletonPose = function (skeleton) {
+ if (this._skeletonPoseDirty)
+ this.updateSkeletonPose(skeleton);
+ return this._skeletonPose;
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonClipState.prototype._pUpdateTime = function (time /*int*/) {
+ this._skeletonPoseDirty = true;
+ _super.prototype._pUpdateTime.call(this, time);
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonClipState.prototype._pUpdateFrames = function () {
+ _super.prototype._pUpdateFrames.call(this);
+ this._currentPose = this._frames[this._pCurrentFrame];
+ if (this._skeletonClipNode.looping && this._pNextFrame >= this._skeletonClipNode.lastFrame) {
+ this._nextPose = this._frames[0];
+ this._pAnimator.dispatchCycleEvent();
+ }
+ else
+ this._nextPose = this._frames[this._pNextFrame];
+ };
+ /**
+ * Updates the output skeleton pose of the node based on the internal playhead position.
+ *
+ * @param skeleton The skeleton used by the animator requesting the ouput pose.
+ */
+ SkeletonClipState.prototype.updateSkeletonPose = function (skeleton) {
+ this._skeletonPoseDirty = false;
+ if (!this._skeletonClipNode.totalDuration)
+ return;
+ if (this._pFramesDirty)
+ this._pUpdateFrames();
+ var currentPose = this._currentPose.jointPoses;
+ var nextPose = this._nextPose.jointPoses;
+ var numJoints = skeleton.numJoints;
+ var p1, p2;
+ var pose1, pose2;
+ var endPoses = this._skeletonPose.jointPoses;
+ var endPose;
+ var tr;
+ // :s
+ if (endPoses.length != numJoints)
+ endPoses.length = numJoints;
+ if ((numJoints != currentPose.length) || (numJoints != nextPose.length))
+ throw new Error("joint counts don't match!");
+ for (var i = 0; i < numJoints; ++i) {
+ endPose = endPoses[i];
+ if (endPose == null)
+ endPose = endPoses[i] = new JointPose();
+ pose1 = currentPose[i];
+ pose2 = nextPose[i];
+ p1 = pose1.translation;
+ p2 = pose2.translation;
+ if (this._skeletonClipNode.highQuality)
+ endPose.orientation.slerp(pose1.orientation, pose2.orientation, this._pBlendWeight);
+ else
+ endPose.orientation.lerp(pose1.orientation, pose2.orientation, this._pBlendWeight);
+ if (i > 0) {
+ tr = endPose.translation;
+ tr.x = p1.x + this._pBlendWeight * (p2.x - p1.x);
+ tr.y = p1.y + this._pBlendWeight * (p2.y - p1.y);
+ tr.z = p1.z + this._pBlendWeight * (p2.z - p1.z);
+ }
+ }
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonClipState.prototype._pUpdatePositionDelta = function () {
+ this._pPositionDeltaDirty = false;
+ if (this._pFramesDirty)
+ this._pUpdateFrames();
+ var p1, p2, p3;
+ var totalDelta = this._skeletonClipNode.totalDelta;
+ // jumping back, need to reset position
+ if ((this._pTimeDir > 0 && this._pNextFrame < this._pOldFrame) || (this._pTimeDir < 0 && this._pNextFrame > this._pOldFrame)) {
+ this._rootPos.x -= totalDelta.x * this._pTimeDir;
+ this._rootPos.y -= totalDelta.y * this._pTimeDir;
+ this._rootPos.z -= totalDelta.z * this._pTimeDir;
+ }
+ var dx = this._rootPos.x;
+ var dy = this._rootPos.y;
+ var dz = this._rootPos.z;
+ if (this._skeletonClipNode.stitchFinalFrame && this._pNextFrame == this._skeletonClipNode.lastFrame) {
+ p1 = this._frames[0].jointPoses[0].translation;
+ p2 = this._frames[1].jointPoses[0].translation;
+ p3 = this._currentPose.jointPoses[0].translation;
+ this._rootPos.x = p3.x + p1.x + this._pBlendWeight * (p2.x - p1.x);
+ this._rootPos.y = p3.y + p1.y + this._pBlendWeight * (p2.y - p1.y);
+ this._rootPos.z = p3.z + p1.z + this._pBlendWeight * (p2.z - p1.z);
+ }
+ else {
+ p1 = this._currentPose.jointPoses[0].translation;
+ p2 = this._frames[this._pNextFrame].jointPoses[0].translation; //cover the instances where we wrap the pose but still want the final frame translation values
+ this._rootPos.x = p1.x + this._pBlendWeight * (p2.x - p1.x);
+ this._rootPos.y = p1.y + this._pBlendWeight * (p2.y - p1.y);
+ this._rootPos.z = p1.z + this._pBlendWeight * (p2.z - p1.z);
+ }
+ this._pRootDelta.x = this._rootPos.x - dx;
+ this._pRootDelta.y = this._rootPos.y - dy;
+ this._pRootDelta.z = this._rootPos.z - dz;
+ this._pOldFrame = this._pNextFrame;
+ };
+ return SkeletonClipState;
+})(AnimationClipState);
+module.exports = SkeletonClipState;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/states/skeletonclipstate.ts"],"names":["SkeletonClipState","SkeletonClipState.constructor","SkeletonClipState.currentPose","SkeletonClipState.nextPose","SkeletonClipState.getSkeletonPose","SkeletonClipState._pUpdateTime","SkeletonClipState._pUpdateFrames","SkeletonClipState.updateSkeletonPose","SkeletonClipState._pUpdatePositionDelta"],"mappings":"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ACA,CAACA,GAACA,IAAIA,CAACA,SAASA,CAACA;YAC/CA,IAAIA,CAACA,QAAQA,CAACA,CAACA,IAAIA,UAAUA,CAACA,CAACA,GAACA,IAAIA,CAACA,SAASA,CAACA;QAChDA,CAACA;QAEDA,IAAIA,EAAEA,GAAUA,IAAIA,CAACA,QAAQA,CAACA,CAACA,CAACA;QAChCA,IAAIA,EAAEA,GAAUA,IAAIA,CAACA,QAAQA,CAACA,CAACA,CAACA;QAChCA,IAAIA,EAAEA,GAAUA,IAAIA,CAACA,QAAQA,CAACA,CAACA,CAACA;QAEhCA,EAAEA,CAACA,CAACA,IAAIA,CAACA,iBAAiBA,CAACA,gBAAgBA,IAAIA,IAAIA,CAACA,WAAWA,IAAIA,IAAIA,CAACA,iBAAiBA,CAACA,SAASA,CAACA,CAACA,CAACA;YACrGA,EAAEA,GAAGA,IAAIA,CAACA,OAAOA,CAACA,CAACA,CAACA,CAACA,UAAUA,CAACA,CAACA,CAACA,CAACA,WAAWA,CAACA;YAC/CA,EAAEA,GAAGA,IAAIA,CAACA,OAAOA,CAACA,CAACA,CAACA,CAACA,UAAUA,CAACA,CAACA,CAACA,CAACA,WAAWA,CAACA;YAC/CA,EAAEA,GAAGA,IAAIA,CAACA,YAAYA,CAACA,UAAUA,CAACA,CAACA,CAACA,CAACA,WAAWA,CAACA;YAEjDA,IAAIA,CAACA,QAAQA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,GAAGA,IAAIA,CAACA,aAAaA,GAACA,CAACA,EAAEA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,CAACA,CAACA;YACjEA,IAAIA,CAACA,QAAQA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,GAAGA,IAAIA,CAACA,aAAaA,GAACA,CAACA,EAAEA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,CAACA,CAACA;YACjEA,IAAIA,CAACA,QAAQA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,GAAGA,IAAIA,CAACA,aAAaA,GAACA,CAACA,EAAEA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,CAACA,CAACA;QAClEA,CAACA;QAACA,IAAIA,CAACA,CAACA;YACPA,EAAEA,GAAGA,IAAIA,CAACA,YAAYA,CAACA,UAAUA,CAACA,CAACA,CAACA,CAACA,WAAWA,CAACA;YACjDA,EAAEA,GAAGA,IAAIA,CAACA,OAAOA,CAACA,IAAIA,CAACA,WAAWA,CAACA,CAACA,UAAUA,CAACA,CAACA,CAACA,CAACA,WAAWA,EAAEA,8FAA8FA;YAC7JA,IAAIA,CAACA,QAAQA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,GAAGA,IAAIA,CAACA,aAAaA,GAACA,CAACA,EAAEA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,CAACA,CAACA;YAC1DA,IAAIA,CAACA,QAAQA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,GAAGA,IAAIA,CAACA,aAAaA,GAACA,CAACA,EAAEA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,CAACA,CAACA;YAC1DA,IAAIA,CAACA,QAAQA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,GAAGA,IAAIA,CAACA,aAAaA,GAACA,CAACA,EAAEA,CAACA,CAACA,GAAGA,EAAEA,CAACA,CAACA,CAACA,CAACA;QAC3DA,CAACA;QAEDA,IAAIA,CAACA,WAAWA,CAACA,CAACA,GAAGA,IAAIA,CAACA,QAAQA,CAACA,CAACA,GAAGA,EAAEA,CAACA;QAC1CA,IAAIA,CAACA,WAAWA,CAACA,CAACA,GAAGA,IAAIA,CAACA,QAAQA,CAACA,CAACA,GAAGA,EAAEA,CAACA;QAC1CA,IAAIA,CAACA,WAAWA,CAACA,CAACA,GAAGA,IAAIA,CAACA,QAAQA,CAACA,CAACA,GAAGA,EAAEA,CAACA;QAE1CA,IAAIA,CAACA,UAAUA,GAAGA,IAAIA,CAACA,WAAWA,CAACA;IACpCA,CAACA;IACFR,wBAACA;AAADA,CAlLA,AAkLCA,EAlL+B,kBAAkB,EAkLjD;AAED,AAA2B,iBAAlB,iBAAiB,CAAC","file":"animators/states/SkeletonClipState.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\n\nimport SkeletonAnimator\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/SkeletonAnimator\");\nimport JointPose\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/JointPose\");\nimport Skeleton\t\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/Skeleton\");\nimport SkeletonPose\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/SkeletonPose\");\nimport SkeletonClipNode\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/SkeletonClipNode\");\nimport AnimationClipState\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/AnimationClipState\");\nimport ISkeletonAnimationState\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ISkeletonAnimationState\");\n\n/**\n *\n */\nclass SkeletonClipState extends AnimationClipState implements ISkeletonAnimationState\n{\n\tprivate _rootPos:Vector3D = new Vector3D();\n\tprivate _frames:Array<SkeletonPose>;\n\tprivate _skeletonClipNode:SkeletonClipNode;\n\tprivate _skeletonPose:SkeletonPose = new SkeletonPose();\n\tprivate _skeletonPoseDirty:boolean = true;\n\tprivate _currentPose:SkeletonPose;\n\tprivate _nextPose:SkeletonPose;\n\n\t/**\n\t * Returns the current skeleton pose frame of animation in the clip based on the internal playhead position.\n\t */\n\tpublic get currentPose():SkeletonPose\n\t{\n\t\tif (this._pFramesDirty)\n\t\t\tthis._pUpdateFrames();\n\n\t\treturn this._currentPose;\n\t}\n\n\t/**\n\t * Returns the next skeleton pose frame of animation in the clip based on the internal playhead position.\n\t */\n\tpublic get nextPose():SkeletonPose\n\t{\n\t\tif (this._pFramesDirty)\n\t\t\tthis._pUpdateFrames();\n\n\t\treturn this._nextPose;\n\t}\n\n\tconstructor(animator:AnimatorBase, skeletonClipNode:SkeletonClipNode)\n\t{\n\t\tsuper(animator, skeletonClipNode);\n\n\t\tthis._skeletonClipNode = skeletonClipNode;\n\t\tthis._frames = this._skeletonClipNode.frames;\n\t}\n\n\t/**\n\t * Returns the current skeleton pose of the animation in the clip based on the internal playhead position.\n\t */\n\tpublic getSkeletonPose(skeleton:Skeleton):SkeletonPose\n\t{\n\t\tif (this._skeletonPoseDirty)\n\t\t\tthis.updateSkeletonPose(skeleton);\n\n\t\treturn this._skeletonPose;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _pUpdateTime(time:number /*int*/)\n\t{\n\t\tthis._skeletonPoseDirty = true;\n\n\t\tsuper._pUpdateTime(time);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _pUpdateFrames()\n\t{\n\t\tsuper._pUpdateFrames();\n\n\t\tthis._currentPose = this._frames[this._pCurrentFrame];\n\n\t\tif (this._skeletonClipNode.looping && this._pNextFrame >= this._skeletonClipNode.lastFrame) {\n\t\t\tthis._nextPose = this._frames[0];\n\t\t\t(<SkeletonAnimator> this._pAnimator).dispatchCycleEvent();\n\t\t} else\n\t\t\tthis._nextPose = this._frames[this._pNextFrame];\n\t}\n\n\t/**\n\t * Updates the output skeleton pose of the node based on the internal playhead position.\n\t *\n\t * @param skeleton The skeleton used by the animator requesting the ouput pose.\n\t */\n\tprivate updateSkeletonPose(skeleton:Skeleton)\n\t{\n\t\tthis._skeletonPoseDirty = false;\n\n\t\tif (!this._skeletonClipNode.totalDuration)\n\t\t\treturn;\n\n\t\tif (this._pFramesDirty)\n\t\t\tthis._pUpdateFrames();\n\n\t\tvar currentPose:Array<JointPose> = this._currentPose.jointPoses;\n\t\tvar nextPose:Array<JointPose> = this._nextPose.jointPoses;\n\t\tvar numJoints:number /*uint*/ = skeleton.numJoints;\n\t\tvar p1:Vector3D, p2:Vector3D;\n\t\tvar pose1:JointPose, pose2:JointPose;\n\t\tvar endPoses:Array<JointPose> = this._skeletonPose.jointPoses;\n\t\tvar endPose:JointPose;\n\t\tvar tr:Vector3D;\n\n\t\t// :s\n\t\tif (endPoses.length != numJoints)\n\t\t\tendPoses.length = numJoints;\n\n\t\tif ((numJoints != currentPose.length) || (numJoints != nextPose.length))\n\t\t\tthrow new Error(\"joint counts don't match!\");\n\n\t\tfor (var i:number /*uint*/ = 0; i < numJoints; ++i) {\n\t\t\tendPose = endPoses[i];\n\n\t\t\tif (endPose == null)\n\t\t\t\tendPose = endPoses[i] = new JointPose();\n\n\t\t\tpose1 = currentPose[i];\n\t\t\tpose2 = nextPose[i];\n\t\t\tp1 = pose1.translation;\n\t\t\tp2 = pose2.translation;\n\n\t\t\tif (this._skeletonClipNode.highQuality)\n\t\t\t\tendPose.orientation.slerp(pose1.orientation, pose2.orientation, this._pBlendWeight); else\n\t\t\t\tendPose.orientation.lerp(pose1.orientation, pose2.orientation, this._pBlendWeight);\n\n\t\t\tif (i > 0) {\n\t\t\t\ttr = endPose.translation;\n\t\t\t\ttr.x = p1.x + this._pBlendWeight*(p2.x - p1.x);\n\t\t\t\ttr.y = p1.y + this._pBlendWeight*(p2.y - p1.y);\n\t\t\t\ttr.z = p1.z + this._pBlendWeight*(p2.z - p1.z);\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _pUpdatePositionDelta()\n\t{\n\t\tthis._pPositionDeltaDirty = false;\n\n\t\tif (this._pFramesDirty)\n\t\t\tthis._pUpdateFrames();\n\n\t\tvar p1:Vector3D, p2:Vector3D, p3:Vector3D;\n\t\tvar totalDelta:Vector3D = this._skeletonClipNode.totalDelta;\n\n\t\t// jumping back, need to reset position\n\t\tif ((this._pTimeDir > 0 && this._pNextFrame < this._pOldFrame) || (this._pTimeDir < 0 && this._pNextFrame > this._pOldFrame)) {\n\t\t\tthis._rootPos.x -= totalDelta.x*this._pTimeDir;\n\t\t\tthis._rootPos.y -= totalDelta.y*this._pTimeDir;\n\t\t\tthis._rootPos.z -= totalDelta.z*this._pTimeDir;\n\t\t}\n\n\t\tvar dx:number = this._rootPos.x;\n\t\tvar dy:number = this._rootPos.y;\n\t\tvar dz:number = this._rootPos.z;\n\n\t\tif (this._skeletonClipNode.stitchFinalFrame && this._pNextFrame == this._skeletonClipNode.lastFrame) {\n\t\t\tp1 = this._frames[0].jointPoses[0].translation;\n\t\t\tp2 = this._frames[1].jointPoses[0].translation;\n\t\t\tp3 = this._currentPose.jointPoses[0].translation;\n\n\t\t\tthis._rootPos.x = p3.x + p1.x + this._pBlendWeight*(p2.x - p1.x);\n\t\t\tthis._rootPos.y = p3.y + p1.y + this._pBlendWeight*(p2.y - p1.y);\n\t\t\tthis._rootPos.z = p3.z + p1.z + this._pBlendWeight*(p2.z - p1.z);\n\t\t} else {\n\t\t\tp1 = this._currentPose.jointPoses[0].translation;\n\t\t\tp2 = this._frames[this._pNextFrame].jointPoses[0].translation; //cover the instances where we wrap the pose but still want the final frame translation values\n\t\t\tthis._rootPos.x = p1.x + this._pBlendWeight*(p2.x - p1.x);\n\t\t\tthis._rootPos.y = p1.y + this._pBlendWeight*(p2.y - p1.y);\n\t\t\tthis._rootPos.z = p1.z + this._pBlendWeight*(p2.z - p1.z);\n\t\t}\n\n\t\tthis._pRootDelta.x = this._rootPos.x - dx;\n\t\tthis._pRootDelta.y = this._rootPos.y - dy;\n\t\tthis._pRootDelta.z = this._rootPos.z - dz;\n\n\t\tthis._pOldFrame = this._pNextFrame;\n\t}\n}\n\nexport = SkeletonClipState;"]}
\ No newline at end of file
diff --git a/lib/animators/states/SkeletonClipState.ts b/lib/animators/states/SkeletonClipState.ts
new file mode 100644
index 000000000..c49d33ec6
--- /dev/null
+++ b/lib/animators/states/SkeletonClipState.ts
@@ -0,0 +1,196 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+
+import SkeletonAnimator = require("awayjs-renderergl/lib/animators/SkeletonAnimator");
+import JointPose = require("awayjs-renderergl/lib/animators/data/JointPose");
+import Skeleton = require("awayjs-renderergl/lib/animators/data/Skeleton");
+import SkeletonPose = require("awayjs-renderergl/lib/animators/data/SkeletonPose");
+import SkeletonClipNode = require("awayjs-renderergl/lib/animators/nodes/SkeletonClipNode");
+import AnimationClipState = require("awayjs-renderergl/lib/animators/states/AnimationClipState");
+import ISkeletonAnimationState = require("awayjs-renderergl/lib/animators/states/ISkeletonAnimationState");
+
+/**
+ *
+ */
+class SkeletonClipState extends AnimationClipState implements ISkeletonAnimationState
+{
+ private _rootPos:Vector3D = new Vector3D();
+ private _frames:Array;
+ private _skeletonClipNode:SkeletonClipNode;
+ private _skeletonPose:SkeletonPose = new SkeletonPose();
+ private _skeletonPoseDirty:boolean = true;
+ private _currentPose:SkeletonPose;
+ private _nextPose:SkeletonPose;
+
+ /**
+ * Returns the current skeleton pose frame of animation in the clip based on the internal playhead position.
+ */
+ public get currentPose():SkeletonPose
+ {
+ if (this._pFramesDirty)
+ this._pUpdateFrames();
+
+ return this._currentPose;
+ }
+
+ /**
+ * Returns the next skeleton pose frame of animation in the clip based on the internal playhead position.
+ */
+ public get nextPose():SkeletonPose
+ {
+ if (this._pFramesDirty)
+ this._pUpdateFrames();
+
+ return this._nextPose;
+ }
+
+ constructor(animator:AnimatorBase, skeletonClipNode:SkeletonClipNode)
+ {
+ super(animator, skeletonClipNode);
+
+ this._skeletonClipNode = skeletonClipNode;
+ this._frames = this._skeletonClipNode.frames;
+ }
+
+ /**
+ * Returns the current skeleton pose of the animation in the clip based on the internal playhead position.
+ */
+ public getSkeletonPose(skeleton:Skeleton):SkeletonPose
+ {
+ if (this._skeletonPoseDirty)
+ this.updateSkeletonPose(skeleton);
+
+ return this._skeletonPose;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pUpdateTime(time:number /*int*/)
+ {
+ this._skeletonPoseDirty = true;
+
+ super._pUpdateTime(time);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pUpdateFrames()
+ {
+ super._pUpdateFrames();
+
+ this._currentPose = this._frames[this._pCurrentFrame];
+
+ if (this._skeletonClipNode.looping && this._pNextFrame >= this._skeletonClipNode.lastFrame) {
+ this._nextPose = this._frames[0];
+ ( this._pAnimator).dispatchCycleEvent();
+ } else
+ this._nextPose = this._frames[this._pNextFrame];
+ }
+
+ /**
+ * Updates the output skeleton pose of the node based on the internal playhead position.
+ *
+ * @param skeleton The skeleton used by the animator requesting the ouput pose.
+ */
+ private updateSkeletonPose(skeleton:Skeleton)
+ {
+ this._skeletonPoseDirty = false;
+
+ if (!this._skeletonClipNode.totalDuration)
+ return;
+
+ if (this._pFramesDirty)
+ this._pUpdateFrames();
+
+ var currentPose:Array = this._currentPose.jointPoses;
+ var nextPose:Array = this._nextPose.jointPoses;
+ var numJoints:number /*uint*/ = skeleton.numJoints;
+ var p1:Vector3D, p2:Vector3D;
+ var pose1:JointPose, pose2:JointPose;
+ var endPoses:Array = this._skeletonPose.jointPoses;
+ var endPose:JointPose;
+ var tr:Vector3D;
+
+ // :s
+ if (endPoses.length != numJoints)
+ endPoses.length = numJoints;
+
+ if ((numJoints != currentPose.length) || (numJoints != nextPose.length))
+ throw new Error("joint counts don't match!");
+
+ for (var i:number /*uint*/ = 0; i < numJoints; ++i) {
+ endPose = endPoses[i];
+
+ if (endPose == null)
+ endPose = endPoses[i] = new JointPose();
+
+ pose1 = currentPose[i];
+ pose2 = nextPose[i];
+ p1 = pose1.translation;
+ p2 = pose2.translation;
+
+ if (this._skeletonClipNode.highQuality)
+ endPose.orientation.slerp(pose1.orientation, pose2.orientation, this._pBlendWeight); else
+ endPose.orientation.lerp(pose1.orientation, pose2.orientation, this._pBlendWeight);
+
+ if (i > 0) {
+ tr = endPose.translation;
+ tr.x = p1.x + this._pBlendWeight*(p2.x - p1.x);
+ tr.y = p1.y + this._pBlendWeight*(p2.y - p1.y);
+ tr.z = p1.z + this._pBlendWeight*(p2.z - p1.z);
+ }
+ }
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pUpdatePositionDelta()
+ {
+ this._pPositionDeltaDirty = false;
+
+ if (this._pFramesDirty)
+ this._pUpdateFrames();
+
+ var p1:Vector3D, p2:Vector3D, p3:Vector3D;
+ var totalDelta:Vector3D = this._skeletonClipNode.totalDelta;
+
+ // jumping back, need to reset position
+ if ((this._pTimeDir > 0 && this._pNextFrame < this._pOldFrame) || (this._pTimeDir < 0 && this._pNextFrame > this._pOldFrame)) {
+ this._rootPos.x -= totalDelta.x*this._pTimeDir;
+ this._rootPos.y -= totalDelta.y*this._pTimeDir;
+ this._rootPos.z -= totalDelta.z*this._pTimeDir;
+ }
+
+ var dx:number = this._rootPos.x;
+ var dy:number = this._rootPos.y;
+ var dz:number = this._rootPos.z;
+
+ if (this._skeletonClipNode.stitchFinalFrame && this._pNextFrame == this._skeletonClipNode.lastFrame) {
+ p1 = this._frames[0].jointPoses[0].translation;
+ p2 = this._frames[1].jointPoses[0].translation;
+ p3 = this._currentPose.jointPoses[0].translation;
+
+ this._rootPos.x = p3.x + p1.x + this._pBlendWeight*(p2.x - p1.x);
+ this._rootPos.y = p3.y + p1.y + this._pBlendWeight*(p2.y - p1.y);
+ this._rootPos.z = p3.z + p1.z + this._pBlendWeight*(p2.z - p1.z);
+ } else {
+ p1 = this._currentPose.jointPoses[0].translation;
+ p2 = this._frames[this._pNextFrame].jointPoses[0].translation; //cover the instances where we wrap the pose but still want the final frame translation values
+ this._rootPos.x = p1.x + this._pBlendWeight*(p2.x - p1.x);
+ this._rootPos.y = p1.y + this._pBlendWeight*(p2.y - p1.y);
+ this._rootPos.z = p1.z + this._pBlendWeight*(p2.z - p1.z);
+ }
+
+ this._pRootDelta.x = this._rootPos.x - dx;
+ this._pRootDelta.y = this._rootPos.y - dy;
+ this._pRootDelta.z = this._rootPos.z - dz;
+
+ this._pOldFrame = this._pNextFrame;
+ }
+}
+
+export = SkeletonClipState;
\ No newline at end of file
diff --git a/lib/animators/states/SkeletonDifferenceState.js b/lib/animators/states/SkeletonDifferenceState.js
new file mode 100755
index 000000000..52c964a13
--- /dev/null
+++ b/lib/animators/states/SkeletonDifferenceState.js
@@ -0,0 +1,120 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Quaternion = require("awayjs-core/lib/core/geom/Quaternion");
+var JointPose = require("awayjs-renderergl/lib/animators/data/JointPose");
+var SkeletonPose = require("awayjs-renderergl/lib/animators/data/SkeletonPose");
+var AnimationStateBase = require("awayjs-renderergl/lib/animators/states/AnimationStateBase");
+/**
+ *
+ */
+var SkeletonDifferenceState = (function (_super) {
+ __extends(SkeletonDifferenceState, _super);
+ function SkeletonDifferenceState(animator, skeletonAnimationNode) {
+ _super.call(this, animator, skeletonAnimationNode);
+ this._blendWeight = 0;
+ this._skeletonPose = new SkeletonPose();
+ this._skeletonPoseDirty = true;
+ this._skeletonAnimationNode = skeletonAnimationNode;
+ this._baseInput = animator.getAnimationState(this._skeletonAnimationNode.baseInput);
+ this._differenceInput = animator.getAnimationState(this._skeletonAnimationNode.differenceInput);
+ }
+ Object.defineProperty(SkeletonDifferenceState.prototype, "blendWeight", {
+ /**
+ * Defines a fractional value between 0 and 1 representing the blending ratio between the base input (0) and difference input (1),
+ * used to produce the skeleton pose output.
+ *
+ * @see #baseInput
+ * @see #differenceInput
+ */
+ get: function () {
+ return this._blendWeight;
+ },
+ set: function (value) {
+ this._blendWeight = value;
+ this._pPositionDeltaDirty = true;
+ this._skeletonPoseDirty = true;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ SkeletonDifferenceState.prototype.phase = function (value) {
+ this._skeletonPoseDirty = true;
+ this._pPositionDeltaDirty = true;
+ this._baseInput.phase(value);
+ this._baseInput.phase(value);
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonDifferenceState.prototype._pUpdateTime = function (time /*int*/) {
+ this._skeletonPoseDirty = true;
+ this._baseInput.update(time);
+ this._differenceInput.update(time);
+ _super.prototype._pUpdateTime.call(this, time);
+ };
+ /**
+ * Returns the current skeleton pose of the animation in the clip based on the internal playhead position.
+ */
+ SkeletonDifferenceState.prototype.getSkeletonPose = function (skeleton) {
+ if (this._skeletonPoseDirty)
+ this.updateSkeletonPose(skeleton);
+ return this._skeletonPose;
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonDifferenceState.prototype._pUpdatePositionDelta = function () {
+ this._pPositionDeltaDirty = false;
+ var deltA = this._baseInput.positionDelta;
+ var deltB = this._differenceInput.positionDelta;
+ this.positionDelta.x = deltA.x + this._blendWeight * deltB.x;
+ this.positionDelta.y = deltA.y + this._blendWeight * deltB.y;
+ this.positionDelta.z = deltA.z + this._blendWeight * deltB.z;
+ };
+ /**
+ * Updates the output skeleton pose of the node based on the blendWeight value between base input and difference input nodes.
+ *
+ * @param skeleton The skeleton used by the animator requesting the ouput pose.
+ */
+ SkeletonDifferenceState.prototype.updateSkeletonPose = function (skeleton) {
+ this._skeletonPoseDirty = false;
+ var endPose;
+ var endPoses = this._skeletonPose.jointPoses;
+ var basePoses = this._baseInput.getSkeletonPose(skeleton).jointPoses;
+ var diffPoses = this._differenceInput.getSkeletonPose(skeleton).jointPoses;
+ var base, diff;
+ var basePos, diffPos;
+ var tr;
+ var numJoints = skeleton.numJoints;
+ // :s
+ if (endPoses.length != numJoints)
+ endPoses.length = numJoints;
+ for (var i = 0; i < numJoints; ++i) {
+ endPose = endPoses[i];
+ if (endPose == null)
+ endPose = endPoses[i] = new JointPose();
+ base = basePoses[i];
+ diff = diffPoses[i];
+ basePos = base.translation;
+ diffPos = diff.translation;
+ SkeletonDifferenceState._tempQuat.multiply(diff.orientation, base.orientation);
+ endPose.orientation.lerp(base.orientation, SkeletonDifferenceState._tempQuat, this._blendWeight);
+ tr = endPose.translation;
+ tr.x = basePos.x + this._blendWeight * diffPos.x;
+ tr.y = basePos.y + this._blendWeight * diffPos.y;
+ tr.z = basePos.z + this._blendWeight * diffPos.z;
+ }
+ };
+ SkeletonDifferenceState._tempQuat = new Quaternion();
+ return SkeletonDifferenceState;
+})(AnimationStateBase);
+module.exports = SkeletonDifferenceState;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/states/skeletondifferencestate.ts"],"names":["SkeletonDifferenceState","SkeletonDifferenceState.constructor","SkeletonDifferenceState.blendWeight","SkeletonDifferenceState.phase","SkeletonDifferenceState._pUpdateTime","SkeletonDifferenceState.getSkeletonPose","SkeletonDifferenceState._pUpdatePositionDelta","SkeletonDifferenceState.updateSkeletonPose"],"mappings":"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","file":"animators/states/SkeletonDifferenceState.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Quaternion\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Quaternion\");\nimport Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\n\nimport JointPose\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/JointPose\");\nimport Skeleton\t\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/Skeleton\");\nimport SkeletonPose\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/SkeletonPose\");\nimport SkeletonDifferenceNode\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/SkeletonDifferenceNode\");\nimport AnimationStateBase\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/AnimationStateBase\");\nimport ISkeletonAnimationState\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ISkeletonAnimationState\");\n\n/**\n *\n */\nclass SkeletonDifferenceState extends AnimationStateBase implements ISkeletonAnimationState\n{\n\tprivate _blendWeight:number = 0;\n\tprivate static _tempQuat:Quaternion = new Quaternion();\n\tprivate _skeletonAnimationNode:SkeletonDifferenceNode;\n\tprivate _skeletonPose:SkeletonPose = new SkeletonPose();\n\tprivate _skeletonPoseDirty:boolean = true;\n\tprivate _baseInput:ISkeletonAnimationState;\n\tprivate _differenceInput:ISkeletonAnimationState;\n\n\t/**\n\t * Defines a fractional value between 0 and 1 representing the blending ratio between the base input (0) and difference input (1),\n\t * used to produce the skeleton pose output.\n\t *\n\t * @see #baseInput\n\t * @see #differenceInput\n\t */\n\tpublic get blendWeight():number\n\t{\n\t\treturn this._blendWeight;\n\t}\n\n\tpublic set blendWeight(value:number)\n\t{\n\t\tthis._blendWeight = value;\n\n\t\tthis._pPositionDeltaDirty = true;\n\t\tthis._skeletonPoseDirty = true;\n\t}\n\n\tconstructor(animator:AnimatorBase, skeletonAnimationNode:SkeletonDifferenceNode)\n\t{\n\t\tsuper(animator, skeletonAnimationNode);\n\n\t\tthis._skeletonAnimationNode = skeletonAnimationNode;\n\n\t\tthis._baseInput = <ISkeletonAnimationState> animator.getAnimationState(this._skeletonAnimationNode.baseInput);\n\t\tthis._differenceInput = <ISkeletonAnimationState> animator.getAnimationState(this._skeletonAnimationNode.differenceInput);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic phase(value:number)\n\t{\n\t\tthis._skeletonPoseDirty = true;\n\n\t\tthis._pPositionDeltaDirty = true;\n\n\t\tthis._baseInput.phase(value);\n\t\tthis._baseInput.phase(value);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _pUpdateTime(time:number /*int*/)\n\t{\n\t\tthis._skeletonPoseDirty = true;\n\n\t\tthis._baseInput.update(time);\n\t\tthis._differenceInput.update(time);\n\n\t\tsuper._pUpdateTime(time);\n\t}\n\n\t/**\n\t * Returns the current skeleton pose of the animation in the clip based on the internal playhead position.\n\t */\n\tpublic getSkeletonPose(skeleton:Skeleton):SkeletonPose\n\t{\n\t\tif (this._skeletonPoseDirty)\n\t\t\tthis.updateSkeletonPose(skeleton);\n\n\t\treturn this._skeletonPose;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _pUpdatePositionDelta()\n\t{\n\t\tthis._pPositionDeltaDirty = false;\n\n\t\tvar deltA:Vector3D = this._baseInput.positionDelta;\n\t\tvar deltB:Vector3D = this._differenceInput.positionDelta;\n\n\t\tthis.positionDelta.x = deltA.x + this._blendWeight*deltB.x;\n\t\tthis.positionDelta.y = deltA.y + this._blendWeight*deltB.y;\n\t\tthis.positionDelta.z = deltA.z + this._blendWeight*deltB.z;\n\t}\n\n\t/**\n\t * Updates the output skeleton pose of the node based on the blendWeight value between base input and difference input nodes.\n\t *\n\t * @param skeleton The skeleton used by the animator requesting the ouput pose.\n\t */\n\tprivate updateSkeletonPose(skeleton:Skeleton)\n\t{\n\t\tthis._skeletonPoseDirty = false;\n\n\t\tvar endPose:JointPose;\n\t\tvar endPoses:Array<JointPose> = this._skeletonPose.jointPoses;\n\t\tvar basePoses:Array<JointPose> = this._baseInput.getSkeletonPose(skeleton).jointPoses;\n\t\tvar diffPoses:Array<JointPose> = this._differenceInput.getSkeletonPose(skeleton).jointPoses;\n\t\tvar base:JointPose, diff:JointPose;\n\t\tvar basePos:Vector3D, diffPos:Vector3D;\n\t\tvar tr:Vector3D;\n\t\tvar numJoints:number /*uint*/ = skeleton.numJoints;\n\n\t\t// :s\n\t\tif (endPoses.length != numJoints)\n\t\t\tendPoses.length = numJoints;\n\n\t\tfor (var i:number /*uint*/ = 0; i < numJoints; ++i) {\n\t\t\tendPose = endPoses[i];\n\n\t\t\tif (endPose == null)\n\t\t\t\tendPose = endPoses[i] = new JointPose();\n\n\t\t\tbase = basePoses[i];\n\t\t\tdiff = diffPoses[i];\n\t\t\tbasePos = base.translation;\n\t\t\tdiffPos = diff.translation;\n\n\t\t\tSkeletonDifferenceState._tempQuat.multiply(diff.orientation, base.orientation);\n\t\t\tendPose.orientation.lerp(base.orientation, SkeletonDifferenceState._tempQuat, this._blendWeight);\n\n\t\t\ttr = endPose.translation;\n\t\t\ttr.x = basePos.x + this._blendWeight*diffPos.x;\n\t\t\ttr.y = basePos.y + this._blendWeight*diffPos.y;\n\t\t\ttr.z = basePos.z + this._blendWeight*diffPos.z;\n\t\t}\n\t}\n}\n\nexport = SkeletonDifferenceState;"]}
\ No newline at end of file
diff --git a/lib/animators/states/SkeletonDifferenceState.ts b/lib/animators/states/SkeletonDifferenceState.ts
new file mode 100644
index 000000000..d342ede65
--- /dev/null
+++ b/lib/animators/states/SkeletonDifferenceState.ts
@@ -0,0 +1,152 @@
+import Quaternion = require("awayjs-core/lib/core/geom/Quaternion");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+
+import JointPose = require("awayjs-renderergl/lib/animators/data/JointPose");
+import Skeleton = require("awayjs-renderergl/lib/animators/data/Skeleton");
+import SkeletonPose = require("awayjs-renderergl/lib/animators/data/SkeletonPose");
+import SkeletonDifferenceNode = require("awayjs-renderergl/lib/animators/nodes/SkeletonDifferenceNode");
+import AnimationStateBase = require("awayjs-renderergl/lib/animators/states/AnimationStateBase");
+import ISkeletonAnimationState = require("awayjs-renderergl/lib/animators/states/ISkeletonAnimationState");
+
+/**
+ *
+ */
+class SkeletonDifferenceState extends AnimationStateBase implements ISkeletonAnimationState
+{
+ private _blendWeight:number = 0;
+ private static _tempQuat:Quaternion = new Quaternion();
+ private _skeletonAnimationNode:SkeletonDifferenceNode;
+ private _skeletonPose:SkeletonPose = new SkeletonPose();
+ private _skeletonPoseDirty:boolean = true;
+ private _baseInput:ISkeletonAnimationState;
+ private _differenceInput:ISkeletonAnimationState;
+
+ /**
+ * Defines a fractional value between 0 and 1 representing the blending ratio between the base input (0) and difference input (1),
+ * used to produce the skeleton pose output.
+ *
+ * @see #baseInput
+ * @see #differenceInput
+ */
+ public get blendWeight():number
+ {
+ return this._blendWeight;
+ }
+
+ public set blendWeight(value:number)
+ {
+ this._blendWeight = value;
+
+ this._pPositionDeltaDirty = true;
+ this._skeletonPoseDirty = true;
+ }
+
+ constructor(animator:AnimatorBase, skeletonAnimationNode:SkeletonDifferenceNode)
+ {
+ super(animator, skeletonAnimationNode);
+
+ this._skeletonAnimationNode = skeletonAnimationNode;
+
+ this._baseInput = animator.getAnimationState(this._skeletonAnimationNode.baseInput);
+ this._differenceInput = animator.getAnimationState(this._skeletonAnimationNode.differenceInput);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public phase(value:number)
+ {
+ this._skeletonPoseDirty = true;
+
+ this._pPositionDeltaDirty = true;
+
+ this._baseInput.phase(value);
+ this._baseInput.phase(value);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pUpdateTime(time:number /*int*/)
+ {
+ this._skeletonPoseDirty = true;
+
+ this._baseInput.update(time);
+ this._differenceInput.update(time);
+
+ super._pUpdateTime(time);
+ }
+
+ /**
+ * Returns the current skeleton pose of the animation in the clip based on the internal playhead position.
+ */
+ public getSkeletonPose(skeleton:Skeleton):SkeletonPose
+ {
+ if (this._skeletonPoseDirty)
+ this.updateSkeletonPose(skeleton);
+
+ return this._skeletonPose;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pUpdatePositionDelta()
+ {
+ this._pPositionDeltaDirty = false;
+
+ var deltA:Vector3D = this._baseInput.positionDelta;
+ var deltB:Vector3D = this._differenceInput.positionDelta;
+
+ this.positionDelta.x = deltA.x + this._blendWeight*deltB.x;
+ this.positionDelta.y = deltA.y + this._blendWeight*deltB.y;
+ this.positionDelta.z = deltA.z + this._blendWeight*deltB.z;
+ }
+
+ /**
+ * Updates the output skeleton pose of the node based on the blendWeight value between base input and difference input nodes.
+ *
+ * @param skeleton The skeleton used by the animator requesting the ouput pose.
+ */
+ private updateSkeletonPose(skeleton:Skeleton)
+ {
+ this._skeletonPoseDirty = false;
+
+ var endPose:JointPose;
+ var endPoses:Array = this._skeletonPose.jointPoses;
+ var basePoses:Array = this._baseInput.getSkeletonPose(skeleton).jointPoses;
+ var diffPoses:Array = this._differenceInput.getSkeletonPose(skeleton).jointPoses;
+ var base:JointPose, diff:JointPose;
+ var basePos:Vector3D, diffPos:Vector3D;
+ var tr:Vector3D;
+ var numJoints:number /*uint*/ = skeleton.numJoints;
+
+ // :s
+ if (endPoses.length != numJoints)
+ endPoses.length = numJoints;
+
+ for (var i:number /*uint*/ = 0; i < numJoints; ++i) {
+ endPose = endPoses[i];
+
+ if (endPose == null)
+ endPose = endPoses[i] = new JointPose();
+
+ base = basePoses[i];
+ diff = diffPoses[i];
+ basePos = base.translation;
+ diffPos = diff.translation;
+
+ SkeletonDifferenceState._tempQuat.multiply(diff.orientation, base.orientation);
+ endPose.orientation.lerp(base.orientation, SkeletonDifferenceState._tempQuat, this._blendWeight);
+
+ tr = endPose.translation;
+ tr.x = basePos.x + this._blendWeight*diffPos.x;
+ tr.y = basePos.y + this._blendWeight*diffPos.y;
+ tr.z = basePos.z + this._blendWeight*diffPos.z;
+ }
+ }
+}
+
+export = SkeletonDifferenceState;
\ No newline at end of file
diff --git a/lib/animators/states/SkeletonDirectionalState.js b/lib/animators/states/SkeletonDirectionalState.js
new file mode 100755
index 000000000..2313201d1
--- /dev/null
+++ b/lib/animators/states/SkeletonDirectionalState.js
@@ -0,0 +1,162 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var JointPose = require("awayjs-renderergl/lib/animators/data/JointPose");
+var SkeletonPose = require("awayjs-renderergl/lib/animators/data/SkeletonPose");
+var AnimationStateBase = require("awayjs-renderergl/lib/animators/states/AnimationStateBase");
+/**
+ *
+ */
+var SkeletonDirectionalState = (function (_super) {
+ __extends(SkeletonDirectionalState, _super);
+ function SkeletonDirectionalState(animator, skeletonAnimationNode) {
+ _super.call(this, animator, skeletonAnimationNode);
+ this._skeletonPose = new SkeletonPose();
+ this._skeletonPoseDirty = true;
+ this._blendWeight = 0;
+ this._direction = 0;
+ this._blendDirty = true;
+ this._skeletonAnimationNode = skeletonAnimationNode;
+ this._forward = animator.getAnimationState(this._skeletonAnimationNode.forward);
+ this._backward = animator.getAnimationState(this._skeletonAnimationNode.backward);
+ this._left = animator.getAnimationState(this._skeletonAnimationNode.left);
+ this._right = animator.getAnimationState(this._skeletonAnimationNode.right);
+ }
+ Object.defineProperty(SkeletonDirectionalState.prototype, "direction", {
+ get: function () {
+ return this._direction;
+ },
+ /**
+ * Defines the direction in degrees of the aniamtion between the forwards (0), right(90) backwards (180) and left(270) input nodes,
+ * used to produce the skeleton pose output.
+ */
+ set: function (value) {
+ if (this._direction == value)
+ return;
+ this._direction = value;
+ this._blendDirty = true;
+ this._skeletonPoseDirty = true;
+ this._pPositionDeltaDirty = true;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ SkeletonDirectionalState.prototype.phase = function (value) {
+ if (this._blendDirty)
+ this.updateBlend();
+ this._skeletonPoseDirty = true;
+ this._pPositionDeltaDirty = true;
+ this._inputA.phase(value);
+ this._inputB.phase(value);
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonDirectionalState.prototype._pUdateTime = function (time /*int*/) {
+ if (this._blendDirty)
+ this.updateBlend();
+ this._skeletonPoseDirty = true;
+ this._inputA.update(time);
+ this._inputB.update(time);
+ _super.prototype._pUpdateTime.call(this, time);
+ };
+ /**
+ * Returns the current skeleton pose of the animation in the clip based on the internal playhead position.
+ */
+ SkeletonDirectionalState.prototype.getSkeletonPose = function (skeleton) {
+ if (this._skeletonPoseDirty)
+ this.updateSkeletonPose(skeleton);
+ return this._skeletonPose;
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonDirectionalState.prototype._pUpdatePositionDelta = function () {
+ this._pPositionDeltaDirty = false;
+ if (this._blendDirty)
+ this.updateBlend();
+ var deltA = this._inputA.positionDelta;
+ var deltB = this._inputB.positionDelta;
+ this.positionDelta.x = deltA.x + this._blendWeight * (deltB.x - deltA.x);
+ this.positionDelta.y = deltA.y + this._blendWeight * (deltB.y - deltA.y);
+ this.positionDelta.z = deltA.z + this._blendWeight * (deltB.z - deltA.z);
+ };
+ /**
+ * Updates the output skeleton pose of the node based on the direction value between forward, backwards, left and right input nodes.
+ *
+ * @param skeleton The skeleton used by the animator requesting the ouput pose.
+ */
+ SkeletonDirectionalState.prototype.updateSkeletonPose = function (skeleton) {
+ this._skeletonPoseDirty = false;
+ if (this._blendDirty)
+ this.updateBlend();
+ var endPose;
+ var endPoses = this._skeletonPose.jointPoses;
+ var poses1 = this._inputA.getSkeletonPose(skeleton).jointPoses;
+ var poses2 = this._inputB.getSkeletonPose(skeleton).jointPoses;
+ var pose1, pose2;
+ var p1, p2;
+ var tr;
+ var numJoints = skeleton.numJoints;
+ // :s
+ if (endPoses.length != numJoints)
+ endPoses.length = numJoints;
+ for (var i = 0; i < numJoints; ++i) {
+ endPose = endPoses[i];
+ if (endPose == null)
+ endPose = endPoses[i] = new JointPose();
+ pose1 = poses1[i];
+ pose2 = poses2[i];
+ p1 = pose1.translation;
+ p2 = pose2.translation;
+ endPose.orientation.lerp(pose1.orientation, pose2.orientation, this._blendWeight);
+ tr = endPose.translation;
+ tr.x = p1.x + this._blendWeight * (p2.x - p1.x);
+ tr.y = p1.y + this._blendWeight * (p2.y - p1.y);
+ tr.z = p1.z + this._blendWeight * (p2.z - p1.z);
+ }
+ };
+ /**
+ * Updates the blend value for the animation output based on the direction value between forward, backwards, left and right input nodes.
+ *
+ * @private
+ */
+ SkeletonDirectionalState.prototype.updateBlend = function () {
+ this._blendDirty = false;
+ if (this._direction < 0 || this._direction > 360) {
+ this._direction %= 360;
+ if (this._direction < 0)
+ this._direction += 360;
+ }
+ if (this._direction < 90) {
+ this._inputA = this._forward;
+ this._inputB = this._right;
+ this._blendWeight = this._direction / 90;
+ }
+ else if (this._direction < 180) {
+ this._inputA = this._right;
+ this._inputB = this._backward;
+ this._blendWeight = (this._direction - 90) / 90;
+ }
+ else if (this._direction < 270) {
+ this._inputA = this._backward;
+ this._inputB = this._left;
+ this._blendWeight = (this._direction - 180) / 90;
+ }
+ else {
+ this._inputA = this._left;
+ this._inputB = this._forward;
+ this._blendWeight = (this._direction - 270) / 90;
+ }
+ };
+ return SkeletonDirectionalState;
+})(AnimationStateBase);
+module.exports = SkeletonDirectionalState;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/states/skeletondirectionalstate.ts"],"names":["SkeletonDirectionalState","SkeletonDirectionalState.constructor","SkeletonDirectionalState.direction","SkeletonDirectionalState.phase","SkeletonDirectionalState._pUdateTime","SkeletonDirectionalState.getSkeletonPose","SkeletonDirectionalState._pUpdatePositionDelta","SkeletonDirectionalState.updateSkeletonPose","SkeletonDirectionalState.updateBlend"],"mappings":"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","file":"animators/states/SkeletonDirectionalState.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\n\nimport JointPose\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/JointPose\");\nimport Skeleton\t\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/Skeleton\");\nimport SkeletonPose\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/SkeletonPose\");\nimport SkeletonDirectionalNode\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/SkeletonDirectionalNode\");\nimport AnimationStateBase\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/AnimationStateBase\");\nimport ISkeletonAnimationState\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ISkeletonAnimationState\");\n\n/**\n *\n */\nclass SkeletonDirectionalState extends AnimationStateBase implements ISkeletonAnimationState\n{\n\tprivate _skeletonAnimationNode:SkeletonDirectionalNode;\n\tprivate _skeletonPose:SkeletonPose = new SkeletonPose();\n\tprivate _skeletonPoseDirty:boolean = true;\n\tprivate _inputA:ISkeletonAnimationState;\n\tprivate _inputB:ISkeletonAnimationState;\n\tprivate _blendWeight:number = 0;\n\tprivate _direction:number = 0;\n\tprivate _blendDirty:boolean = true;\n\tprivate _forward:ISkeletonAnimationState;\n\tprivate _backward:ISkeletonAnimationState;\n\tprivate _left:ISkeletonAnimationState;\n\tprivate _right:ISkeletonAnimationState;\n\n\t/**\n\t * Defines the direction in degrees of the aniamtion between the forwards (0), right(90) backwards (180) and left(270) input nodes,\n\t * used to produce the skeleton pose output.\n\t */\n\tpublic set direction(value:number)\n\t{\n\t\tif (this._direction == value)\n\t\t\treturn;\n\n\t\tthis._direction = value;\n\n\t\tthis._blendDirty = true;\n\n\t\tthis._skeletonPoseDirty = true;\n\t\tthis._pPositionDeltaDirty = true;\n\t}\n\n\tpublic get direction():number\n\t{\n\t\treturn this._direction;\n\t}\n\n\tconstructor(animator:AnimatorBase, skeletonAnimationNode:SkeletonDirectionalNode)\n\t{\n\t\tsuper(animator, skeletonAnimationNode);\n\n\t\tthis._skeletonAnimationNode = skeletonAnimationNode;\n\n\t\tthis._forward = <ISkeletonAnimationState> animator.getAnimationState(this._skeletonAnimationNode.forward);\n\t\tthis._backward = <ISkeletonAnimationState> animator.getAnimationState(this._skeletonAnimationNode.backward);\n\t\tthis._left = <ISkeletonAnimationState> animator.getAnimationState(this._skeletonAnimationNode.left);\n\t\tthis._right = <ISkeletonAnimationState> animator.getAnimationState(this._skeletonAnimationNode.right);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic phase(value:number)\n\t{\n\t\tif (this._blendDirty)\n\t\t\tthis.updateBlend();\n\n\t\tthis._skeletonPoseDirty = true;\n\n\t\tthis._pPositionDeltaDirty = true;\n\n\t\tthis._inputA.phase(value);\n\t\tthis._inputB.phase(value);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _pUdateTime(time:number /*int*/)\n\t{\n\t\tif (this._blendDirty)\n\t\t\tthis.updateBlend();\n\n\t\tthis._skeletonPoseDirty = true;\n\n\t\tthis._inputA.update(time);\n\t\tthis._inputB.update(time);\n\n\t\tsuper._pUpdateTime(time);\n\t}\n\n\t/**\n\t * Returns the current skeleton pose of the animation in the clip based on the internal playhead position.\n\t */\n\tpublic getSkeletonPose(skeleton:Skeleton):SkeletonPose\n\t{\n\t\tif (this._skeletonPoseDirty)\n\t\t\tthis.updateSkeletonPose(skeleton);\n\n\t\treturn this._skeletonPose;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _pUpdatePositionDelta()\n\t{\n\t\tthis._pPositionDeltaDirty = false;\n\n\t\tif (this._blendDirty)\n\t\t\tthis.updateBlend();\n\n\t\tvar deltA:Vector3D = this._inputA.positionDelta;\n\t\tvar deltB:Vector3D = this._inputB.positionDelta;\n\n\t\tthis.positionDelta.x = deltA.x + this._blendWeight*(deltB.x - deltA.x);\n\t\tthis.positionDelta.y = deltA.y + this._blendWeight*(deltB.y - deltA.y);\n\t\tthis.positionDelta.z = deltA.z + this._blendWeight*(deltB.z - deltA.z);\n\t}\n\n\t/**\n\t * Updates the output skeleton pose of the node based on the direction value between forward, backwards, left and right input nodes.\n\t *\n\t * @param skeleton The skeleton used by the animator requesting the ouput pose.\n\t */\n\tprivate updateSkeletonPose(skeleton:Skeleton)\n\t{\n\t\tthis._skeletonPoseDirty = false;\n\n\t\tif (this._blendDirty)\n\t\t\tthis.updateBlend();\n\n\t\tvar endPose:JointPose;\n\t\tvar endPoses:Array<JointPose> = this._skeletonPose.jointPoses;\n\t\tvar poses1:Array<JointPose> = this._inputA.getSkeletonPose(skeleton).jointPoses;\n\t\tvar poses2:Array<JointPose> = this._inputB.getSkeletonPose(skeleton).jointPoses;\n\t\tvar pose1:JointPose, pose2:JointPose;\n\t\tvar p1:Vector3D, p2:Vector3D;\n\t\tvar tr:Vector3D;\n\t\tvar numJoints:number /*uint*/ = skeleton.numJoints;\n\n\t\t// :s\n\t\tif (endPoses.length != numJoints)\n\t\t\tendPoses.length = numJoints;\n\n\t\tfor (var i:number /*uint*/ = 0; i < numJoints; ++i) {\n\t\t\tendPose = endPoses[i];\n\n\t\t\tif (endPose == null)\n\t\t\t\tendPose = endPoses[i] = new JointPose();\n\n\t\t\tpose1 = poses1[i];\n\t\t\tpose2 = poses2[i];\n\t\t\tp1 = pose1.translation;\n\t\t\tp2 = pose2.translation;\n\n\t\t\tendPose.orientation.lerp(pose1.orientation, pose2.orientation, this._blendWeight);\n\n\t\t\ttr = endPose.translation;\n\t\t\ttr.x = p1.x + this._blendWeight*(p2.x - p1.x);\n\t\t\ttr.y = p1.y + this._blendWeight*(p2.y - p1.y);\n\t\t\ttr.z = p1.z + this._blendWeight*(p2.z - p1.z);\n\t\t}\n\t}\n\n\t/**\n\t * Updates the blend value for the animation output based on the direction value between forward, backwards, left and right input nodes.\n\t *\n\t * @private\n\t */\n\tprivate updateBlend()\n\t{\n\t\tthis._blendDirty = false;\n\n\t\tif (this._direction < 0 || this._direction > 360) {\n\t\t\tthis._direction %= 360;\n\t\t\tif (this._direction < 0)\n\t\t\t\tthis._direction += 360;\n\t\t}\n\n\t\tif (this._direction < 90) {\n\t\t\tthis._inputA = this._forward;\n\t\t\tthis._inputB = this._right;\n\t\t\tthis._blendWeight = this._direction/90;\n\t\t} else if (this._direction < 180) {\n\t\t\tthis._inputA = this._right;\n\t\t\tthis._inputB = this._backward;\n\t\t\tthis._blendWeight = (this._direction - 90)/90;\n\t\t} else if (this._direction < 270) {\n\t\t\tthis._inputA = this._backward;\n\t\t\tthis._inputB = this._left;\n\t\t\tthis._blendWeight = (this._direction - 180)/90;\n\t\t} else {\n\t\t\tthis._inputA = this._left;\n\t\t\tthis._inputB = this._forward;\n\t\t\tthis._blendWeight = (this._direction - 270)/90;\n\t\t}\n\t}\n}\n\nexport = SkeletonDirectionalState;"]}
\ No newline at end of file
diff --git a/lib/animators/states/SkeletonDirectionalState.ts b/lib/animators/states/SkeletonDirectionalState.ts
new file mode 100644
index 000000000..bc2047aaa
--- /dev/null
+++ b/lib/animators/states/SkeletonDirectionalState.ts
@@ -0,0 +1,205 @@
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+
+import JointPose = require("awayjs-renderergl/lib/animators/data/JointPose");
+import Skeleton = require("awayjs-renderergl/lib/animators/data/Skeleton");
+import SkeletonPose = require("awayjs-renderergl/lib/animators/data/SkeletonPose");
+import SkeletonDirectionalNode = require("awayjs-renderergl/lib/animators/nodes/SkeletonDirectionalNode");
+import AnimationStateBase = require("awayjs-renderergl/lib/animators/states/AnimationStateBase");
+import ISkeletonAnimationState = require("awayjs-renderergl/lib/animators/states/ISkeletonAnimationState");
+
+/**
+ *
+ */
+class SkeletonDirectionalState extends AnimationStateBase implements ISkeletonAnimationState
+{
+ private _skeletonAnimationNode:SkeletonDirectionalNode;
+ private _skeletonPose:SkeletonPose = new SkeletonPose();
+ private _skeletonPoseDirty:boolean = true;
+ private _inputA:ISkeletonAnimationState;
+ private _inputB:ISkeletonAnimationState;
+ private _blendWeight:number = 0;
+ private _direction:number = 0;
+ private _blendDirty:boolean = true;
+ private _forward:ISkeletonAnimationState;
+ private _backward:ISkeletonAnimationState;
+ private _left:ISkeletonAnimationState;
+ private _right:ISkeletonAnimationState;
+
+ /**
+ * Defines the direction in degrees of the aniamtion between the forwards (0), right(90) backwards (180) and left(270) input nodes,
+ * used to produce the skeleton pose output.
+ */
+ public set direction(value:number)
+ {
+ if (this._direction == value)
+ return;
+
+ this._direction = value;
+
+ this._blendDirty = true;
+
+ this._skeletonPoseDirty = true;
+ this._pPositionDeltaDirty = true;
+ }
+
+ public get direction():number
+ {
+ return this._direction;
+ }
+
+ constructor(animator:AnimatorBase, skeletonAnimationNode:SkeletonDirectionalNode)
+ {
+ super(animator, skeletonAnimationNode);
+
+ this._skeletonAnimationNode = skeletonAnimationNode;
+
+ this._forward = animator.getAnimationState(this._skeletonAnimationNode.forward);
+ this._backward = animator.getAnimationState(this._skeletonAnimationNode.backward);
+ this._left = animator.getAnimationState(this._skeletonAnimationNode.left);
+ this._right = animator.getAnimationState(this._skeletonAnimationNode.right);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public phase(value:number)
+ {
+ if (this._blendDirty)
+ this.updateBlend();
+
+ this._skeletonPoseDirty = true;
+
+ this._pPositionDeltaDirty = true;
+
+ this._inputA.phase(value);
+ this._inputB.phase(value);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pUdateTime(time:number /*int*/)
+ {
+ if (this._blendDirty)
+ this.updateBlend();
+
+ this._skeletonPoseDirty = true;
+
+ this._inputA.update(time);
+ this._inputB.update(time);
+
+ super._pUpdateTime(time);
+ }
+
+ /**
+ * Returns the current skeleton pose of the animation in the clip based on the internal playhead position.
+ */
+ public getSkeletonPose(skeleton:Skeleton):SkeletonPose
+ {
+ if (this._skeletonPoseDirty)
+ this.updateSkeletonPose(skeleton);
+
+ return this._skeletonPose;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pUpdatePositionDelta()
+ {
+ this._pPositionDeltaDirty = false;
+
+ if (this._blendDirty)
+ this.updateBlend();
+
+ var deltA:Vector3D = this._inputA.positionDelta;
+ var deltB:Vector3D = this._inputB.positionDelta;
+
+ this.positionDelta.x = deltA.x + this._blendWeight*(deltB.x - deltA.x);
+ this.positionDelta.y = deltA.y + this._blendWeight*(deltB.y - deltA.y);
+ this.positionDelta.z = deltA.z + this._blendWeight*(deltB.z - deltA.z);
+ }
+
+ /**
+ * Updates the output skeleton pose of the node based on the direction value between forward, backwards, left and right input nodes.
+ *
+ * @param skeleton The skeleton used by the animator requesting the ouput pose.
+ */
+ private updateSkeletonPose(skeleton:Skeleton)
+ {
+ this._skeletonPoseDirty = false;
+
+ if (this._blendDirty)
+ this.updateBlend();
+
+ var endPose:JointPose;
+ var endPoses:Array = this._skeletonPose.jointPoses;
+ var poses1:Array = this._inputA.getSkeletonPose(skeleton).jointPoses;
+ var poses2:Array = this._inputB.getSkeletonPose(skeleton).jointPoses;
+ var pose1:JointPose, pose2:JointPose;
+ var p1:Vector3D, p2:Vector3D;
+ var tr:Vector3D;
+ var numJoints:number /*uint*/ = skeleton.numJoints;
+
+ // :s
+ if (endPoses.length != numJoints)
+ endPoses.length = numJoints;
+
+ for (var i:number /*uint*/ = 0; i < numJoints; ++i) {
+ endPose = endPoses[i];
+
+ if (endPose == null)
+ endPose = endPoses[i] = new JointPose();
+
+ pose1 = poses1[i];
+ pose2 = poses2[i];
+ p1 = pose1.translation;
+ p2 = pose2.translation;
+
+ endPose.orientation.lerp(pose1.orientation, pose2.orientation, this._blendWeight);
+
+ tr = endPose.translation;
+ tr.x = p1.x + this._blendWeight*(p2.x - p1.x);
+ tr.y = p1.y + this._blendWeight*(p2.y - p1.y);
+ tr.z = p1.z + this._blendWeight*(p2.z - p1.z);
+ }
+ }
+
+ /**
+ * Updates the blend value for the animation output based on the direction value between forward, backwards, left and right input nodes.
+ *
+ * @private
+ */
+ private updateBlend()
+ {
+ this._blendDirty = false;
+
+ if (this._direction < 0 || this._direction > 360) {
+ this._direction %= 360;
+ if (this._direction < 0)
+ this._direction += 360;
+ }
+
+ if (this._direction < 90) {
+ this._inputA = this._forward;
+ this._inputB = this._right;
+ this._blendWeight = this._direction/90;
+ } else if (this._direction < 180) {
+ this._inputA = this._right;
+ this._inputB = this._backward;
+ this._blendWeight = (this._direction - 90)/90;
+ } else if (this._direction < 270) {
+ this._inputA = this._backward;
+ this._inputB = this._left;
+ this._blendWeight = (this._direction - 180)/90;
+ } else {
+ this._inputA = this._left;
+ this._inputB = this._forward;
+ this._blendWeight = (this._direction - 270)/90;
+ }
+ }
+}
+
+export = SkeletonDirectionalState;
\ No newline at end of file
diff --git a/lib/animators/states/SkeletonNaryLERPState.js b/lib/animators/states/SkeletonNaryLERPState.js
new file mode 100755
index 000000000..d4d8142b4
--- /dev/null
+++ b/lib/animators/states/SkeletonNaryLERPState.js
@@ -0,0 +1,181 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var JointPose = require("awayjs-renderergl/lib/animators/data/JointPose");
+var SkeletonPose = require("awayjs-renderergl/lib/animators/data/SkeletonPose");
+var AnimationStateBase = require("awayjs-renderergl/lib/animators/states/AnimationStateBase");
+/**
+ *
+ */
+var SkeletonNaryLERPState = (function (_super) {
+ __extends(SkeletonNaryLERPState, _super);
+ function SkeletonNaryLERPState(animator, skeletonAnimationNode) {
+ _super.call(this, animator, skeletonAnimationNode);
+ this._skeletonPose = new SkeletonPose();
+ this._skeletonPoseDirty = true;
+ this._blendWeights = new Array();
+ this._inputs = new Array();
+ this._skeletonAnimationNode = skeletonAnimationNode;
+ var i = this._skeletonAnimationNode.numInputs;
+ while (i--)
+ this._inputs[i] = animator.getAnimationState(this._skeletonAnimationNode._iInputs[i]);
+ }
+ /**
+ * @inheritDoc
+ */
+ SkeletonNaryLERPState.prototype.phase = function (value) {
+ this._skeletonPoseDirty = true;
+ this._pPositionDeltaDirty = true;
+ for (var j = 0; j < this._skeletonAnimationNode.numInputs; ++j) {
+ if (this._blendWeights[j])
+ this._inputs[j].update(value);
+ }
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonNaryLERPState.prototype._pUdateTime = function (time /*int*/) {
+ for (var j = 0; j < this._skeletonAnimationNode.numInputs; ++j) {
+ if (this._blendWeights[j])
+ this._inputs[j].update(time);
+ }
+ _super.prototype._pUpdateTime.call(this, time);
+ };
+ /**
+ * Returns the current skeleton pose of the animation in the clip based on the internal playhead position.
+ */
+ SkeletonNaryLERPState.prototype.getSkeletonPose = function (skeleton) {
+ if (this._skeletonPoseDirty)
+ this.updateSkeletonPose(skeleton);
+ return this._skeletonPose;
+ };
+ /**
+ * Returns the blend weight of the skeleton aniamtion node that resides at the given input index.
+ *
+ * @param index The input index for which the skeleton animation node blend weight is requested.
+ */
+ SkeletonNaryLERPState.prototype.getBlendWeightAt = function (index /*uint*/) {
+ return this._blendWeights[index];
+ };
+ /**
+ * Sets the blend weight of the skeleton aniamtion node that resides at the given input index.
+ *
+ * @param index The input index on which the skeleton animation node blend weight is to be set.
+ * @param blendWeight The blend weight value to use for the given skeleton animation node index.
+ */
+ SkeletonNaryLERPState.prototype.setBlendWeightAt = function (index /*uint*/, blendWeight) {
+ this._blendWeights[index] = blendWeight;
+ this._pPositionDeltaDirty = true;
+ this._skeletonPoseDirty = true;
+ };
+ /**
+ * @inheritDoc
+ */
+ SkeletonNaryLERPState.prototype._pUpdatePositionDelta = function () {
+ this._pPositionDeltaDirty = false;
+ var delta;
+ var weight;
+ this.positionDelta.x = 0;
+ this.positionDelta.y = 0;
+ this.positionDelta.z = 0;
+ for (var j = 0; j < this._skeletonAnimationNode.numInputs; ++j) {
+ weight = this._blendWeights[j];
+ if (weight) {
+ delta = this._inputs[j].positionDelta;
+ this.positionDelta.x += weight * delta.x;
+ this.positionDelta.y += weight * delta.y;
+ this.positionDelta.z += weight * delta.z;
+ }
+ }
+ };
+ /**
+ * Updates the output skeleton pose of the node based on the blend weight values given to the input nodes.
+ *
+ * @param skeleton The skeleton used by the animator requesting the ouput pose.
+ */
+ SkeletonNaryLERPState.prototype.updateSkeletonPose = function (skeleton) {
+ this._skeletonPoseDirty = false;
+ var weight;
+ var endPoses = this._skeletonPose.jointPoses;
+ var poses;
+ var endPose, pose;
+ var endTr, tr;
+ var endQuat, q;
+ var firstPose;
+ var i /*uint*/;
+ var w0, x0, y0, z0;
+ var w1, x1, y1, z1;
+ var numJoints = skeleton.numJoints;
+ // :s
+ if (endPoses.length != numJoints)
+ endPoses.length = numJoints;
+ for (var j = 0; j < this._skeletonAnimationNode.numInputs; ++j) {
+ weight = this._blendWeights[j];
+ if (!weight)
+ continue;
+ poses = this._inputs[j].getSkeletonPose(skeleton).jointPoses;
+ if (!firstPose) {
+ firstPose = poses;
+ for (i = 0; i < numJoints; ++i) {
+ endPose = endPoses[i];
+ if (endPose == null)
+ endPose = endPoses[i] = new JointPose();
+ pose = poses[i];
+ q = pose.orientation;
+ tr = pose.translation;
+ endQuat = endPose.orientation;
+ endQuat.x = weight * q.x;
+ endQuat.y = weight * q.y;
+ endQuat.z = weight * q.z;
+ endQuat.w = weight * q.w;
+ endTr = endPose.translation;
+ endTr.x = weight * tr.x;
+ endTr.y = weight * tr.y;
+ endTr.z = weight * tr.z;
+ }
+ }
+ else {
+ for (i = 0; i < skeleton.numJoints; ++i) {
+ endPose = endPoses[i];
+ pose = poses[i];
+ q = firstPose[i].orientation;
+ x0 = q.x;
+ y0 = q.y;
+ z0 = q.z;
+ w0 = q.w;
+ q = pose.orientation;
+ tr = pose.translation;
+ x1 = q.x;
+ y1 = q.y;
+ z1 = q.z;
+ w1 = q.w;
+ // find shortest direction
+ if (x0 * x1 + y0 * y1 + z0 * z1 + w0 * w1 < 0) {
+ x1 = -x1;
+ y1 = -y1;
+ z1 = -z1;
+ w1 = -w1;
+ }
+ endQuat = endPose.orientation;
+ endQuat.x += weight * x1;
+ endQuat.y += weight * y1;
+ endQuat.z += weight * z1;
+ endQuat.w += weight * w1;
+ endTr = endPose.translation;
+ endTr.x += weight * tr.x;
+ endTr.y += weight * tr.y;
+ endTr.z += weight * tr.z;
+ }
+ }
+ }
+ for (i = 0; i < skeleton.numJoints; ++i)
+ endPoses[i].orientation.normalize();
+ };
+ return SkeletonNaryLERPState;
+})(AnimationStateBase);
+module.exports = SkeletonNaryLERPState;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["animators/states/skeletonnarylerpstate.ts"],"names":["SkeletonNaryLERPState","SkeletonNaryLERPState.constructor","SkeletonNaryLERPState.phase","SkeletonNaryLERPState._pUdateTime","SkeletonNaryLERPState.getSkeletonPose","SkeletonNaryLERPState.getBlendWeightAt","SkeletonNaryLERPState.setBlendWeightAt","SkeletonNaryLERPState._pUpdatePositionDelta","SkeletonNaryLERPState.updateSkeletonPose"],"mappings":"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A,OAAOA,CAACA,CAACA,GAAGA,MAAMA,GAACA,CAACA,CAACA,CAACA,CAACA;oBACvBA,OAAOA,CAACA,CAACA,GAAGA,MAAMA,GAACA,CAACA,CAACA,CAACA,CAACA;oBAEvBA,KAAKA,GAAGA,OAAOA,CAACA,WAAWA,CAACA;oBAC5BA,KAAKA,CAACA,CAACA,GAAGA,MAAMA,GAACA,EAAEA,CAACA,CAACA,CAACA;oBACtBA,KAAKA,CAACA,CAACA,GAAGA,MAAMA,GAACA,EAAEA,CAACA,CAACA,CAACA;oBACtBA,KAAKA,CAACA,CAACA,GAAGA,MAAMA,GAACA,EAAEA,CAACA,CAACA,CAACA;gBACvBA,CAACA;YACFA,CAACA;YAACA,IAAIA,CAACA,CAACA;gBACPA,GAAGA,CAACA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,GAAGA,QAAQA,CAACA,SAASA,EAAEA,EAAEA,CAACA,EAAEA,CAACA;oBACzCA,OAAOA,GAAGA,QAAQA,CAACA,CAACA,CAACA,CAACA;oBACtBA,IAAIA,GAAGA,KAAKA,CAACA,CAACA,CAACA,CAACA;oBAEhBA,CAACA,GAAGA,SAASA,CAACA,CAACA,CAACA,CAACA,WAAWA,CAACA;oBAC7BA,EAAEA,GAAGA,CAACA,CAACA,CAACA,CAACA;oBACTA,EAAEA,GAAGA,CAACA,CAACA,CAACA,CAACA;oBACTA,EAAEA,GAAGA,CAACA,CAACA,CAACA,CAACA;oBACTA,EAAEA,GAAGA,CAACA,CAACA,CAACA,CAACA;oBAETA,CAACA,GAAGA,IAAIA,CAACA,WAAWA,CAACA;oBACrBA,EAAEA,GAAGA,IAAIA,CAACA,WAAWA,CAACA;oBAEtBA,EAAEA,GAAGA,CAACA,CAACA,CAACA,CAACA;oBACTA,EAAEA,GAAGA,CAACA,CAACA,CAACA,CAACA;oBACTA,EAAEA,GAAGA,CAACA,CAACA,CAACA,CAACA;oBACTA,EAAEA,GAAGA,CAACA,CAACA,CAACA,CAACA;oBACTA,AACAA,0BAD0BA;oBAC1BA,EAAEA,CAACA,CAACA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,EAAEA,GAACA,EAAEA,GAAGA,CAACA,CAACA,CAACA,CAACA;wBACvCA,EAAEA,GAAGA,CAACA,EAAEA,CAACA;wBACTA,EAAEA,GAAGA,CAACA,EAAEA,CAACA;wBACTA,EAAEA,GAAGA,CAACA,EAAEA,CAACA;wBACTA,EAAEA,GAAGA,CAACA,EAAEA,CAACA;oBACVA,CAACA;oBACDA,OAAOA,GAAGA,OAAOA,CAACA,WAAWA,CAACA;oBAC9BA,OAAOA,CAACA,CAACA,IAAIA,MAAMA,GAACA,EAAEA,CAACA;oBACvBA,OAAOA,CAACA,CAACA,IAAIA,MAAMA,GAACA,EAAEA,CAACA;oBACvBA,OAAOA,CAACA,CAACA,IAAIA,MAAMA,GAACA,EAAEA,CAACA;oBACvBA,OAAOA,CAACA,CAACA,IAAIA,MAAMA,GAACA,EAAEA,CAACA;oBAEvBA,KAAKA,GAAGA,OAAOA,CAACA,WAAWA,CAACA;oBAC5BA,KAAKA,CAACA,CAACA,IAAIA,MAAMA,GAACA,EAAEA,CAACA,CAACA,CAACA;oBACvBA,KAAKA,CAACA,CAACA,IAAIA,MAAMA,GAACA,EAAEA,CAACA,CAACA,CAACA;oBACvBA,KAAKA,CAACA,CAACA,IAAIA,MAAMA,GAACA,EAAEA,CAACA,CAACA,CAACA;gBACxBA,CAACA;YACFA,CAACA;QACFA,CAACA;QAEDA,GAAGA,CAACA,CAACA,CAACA,GAAGA,CAACA,EAAEA,CAACA,GAAGA,QAAQA,CAACA,SAASA,EAAEA,EAAEA,CAACA;YACtCA,QAAQA,CAACA,CAACA,CAACA,CAACA,WAAWA,CAACA,SAASA,EAAEA,CAACA;IACtCA,CAACA;IACFR,4BAACA;AAADA,CAhNA,AAgNCA,EAhNmC,kBAAkB,EAgNrD;AAED,AAA+B,iBAAtB,qBAAqB,CAAC","file":"animators/states/SkeletonNaryLERPState.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Quaternion\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Quaternion\");\nimport Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\n\nimport AnimatorBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/animators/AnimatorBase\");\n\nimport JointPose\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/JointPose\");\nimport Skeleton\t\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/Skeleton\");\nimport SkeletonPose\t\t\t\t\t\t= require(\"awayjs-renderergl/lib/animators/data/SkeletonPose\");\nimport SkeletonNaryLERPNode\t\t\t\t= require(\"awayjs-renderergl/lib/animators/nodes/SkeletonNaryLERPNode\");\nimport AnimationStateBase\t\t\t\t= require(\"awayjs-renderergl/lib/animators/states/AnimationStateBase\");\nimport ISkeletonAnimationState\t\t\t= require(\"awayjs-renderergl/lib/animators/states/ISkeletonAnimationState\");\n\n/**\n *\n */\nclass SkeletonNaryLERPState extends AnimationStateBase implements ISkeletonAnimationState\n{\n\tprivate _skeletonAnimationNode:SkeletonNaryLERPNode;\n\tprivate _skeletonPose:SkeletonPose = new SkeletonPose();\n\tprivate _skeletonPoseDirty:boolean = true;\n\tprivate _blendWeights:Array<number> = new Array<number>();\n\tprivate _inputs:Array<ISkeletonAnimationState> = new Array<ISkeletonAnimationState>();\n\n\tconstructor(animator:AnimatorBase, skeletonAnimationNode:SkeletonNaryLERPNode)\n\t{\n\t\tsuper(animator, skeletonAnimationNode);\n\n\t\tthis._skeletonAnimationNode = skeletonAnimationNode;\n\n\t\tvar i:number /*uint*/ = this._skeletonAnimationNode.numInputs;\n\n\t\twhile (i--)\n\t\t\tthis._inputs[i] = <ISkeletonAnimationState> animator.getAnimationState(this._skeletonAnimationNode._iInputs[i]);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic phase(value:number)\n\t{\n\t\tthis._skeletonPoseDirty = true;\n\n\t\tthis._pPositionDeltaDirty = true;\n\n\t\tfor (var j:number /*uint*/ = 0; j < this._skeletonAnimationNode.numInputs; ++j) {\n\t\t\tif (this._blendWeights[j])\n\t\t\t\tthis._inputs[j].update(value);\n\t\t}\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _pUdateTime(time:number /*int*/)\n\t{\n\t\tfor (var j:number /*uint*/ = 0; j < this._skeletonAnimationNode.numInputs; ++j) {\n\t\t\tif (this._blendWeights[j])\n\t\t\t\tthis._inputs[j].update(time);\n\t\t}\n\n\t\tsuper._pUpdateTime(time);\n\t}\n\n\t/**\n\t * Returns the current skeleton pose of the animation in the clip based on the internal playhead position.\n\t */\n\tpublic getSkeletonPose(skeleton:Skeleton):SkeletonPose\n\t{\n\t\tif (this._skeletonPoseDirty)\n\t\t\tthis.updateSkeletonPose(skeleton);\n\n\t\treturn this._skeletonPose;\n\t}\n\n\t/**\n\t * Returns the blend weight of the skeleton aniamtion node that resides at the given input index.\n\t *\n\t * @param index The input index for which the skeleton animation node blend weight is requested.\n\t */\n\tpublic getBlendWeightAt(index:number /*uint*/):number\n\t{\n\t\treturn this._blendWeights[index];\n\t}\n\n\t/**\n\t * Sets the blend weight of the skeleton aniamtion node that resides at the given input index.\n\t *\n\t * @param index The input index on which the skeleton animation node blend weight is to be set.\n\t * @param blendWeight The blend weight value to use for the given skeleton animation node index.\n\t */\n\tpublic setBlendWeightAt(index:number /*uint*/, blendWeight:number)\n\t{\n\t\tthis._blendWeights[index] = blendWeight;\n\n\t\tthis._pPositionDeltaDirty = true;\n\t\tthis._skeletonPoseDirty = true;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _pUpdatePositionDelta()\n\t{\n\t\tthis._pPositionDeltaDirty = false;\n\n\t\tvar delta:Vector3D;\n\t\tvar weight:number;\n\n\t\tthis.positionDelta.x = 0;\n\t\tthis.positionDelta.y = 0;\n\t\tthis.positionDelta.z = 0;\n\n\t\tfor (var j:number /*uint*/ = 0; j < this._skeletonAnimationNode.numInputs; ++j) {\n\t\t\tweight = this._blendWeights[j];\n\n\t\t\tif (weight) {\n\t\t\t\tdelta = this._inputs[j].positionDelta;\n\t\t\t\tthis.positionDelta.x += weight*delta.x;\n\t\t\t\tthis.positionDelta.y += weight*delta.y;\n\t\t\t\tthis.positionDelta.z += weight*delta.z;\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Updates the output skeleton pose of the node based on the blend weight values given to the input nodes.\n\t *\n\t * @param skeleton The skeleton used by the animator requesting the ouput pose.\n\t */\n\tprivate updateSkeletonPose(skeleton:Skeleton)\n\t{\n\t\tthis._skeletonPoseDirty = false;\n\n\t\tvar weight:number;\n\t\tvar endPoses:Array<JointPose> = this._skeletonPose.jointPoses;\n\t\tvar poses:Array<JointPose>;\n\t\tvar endPose:JointPose, pose:JointPose;\n\t\tvar endTr:Vector3D, tr:Vector3D;\n\t\tvar endQuat:Quaternion, q:Quaternion;\n\t\tvar firstPose:Array<JointPose>;\n\t\tvar i:number /*uint*/;\n\t\tvar w0:number, x0:number, y0:number, z0:number;\n\t\tvar w1:number, x1:number, y1:number, z1:number;\n\t\tvar numJoints:number /*uint*/ = skeleton.numJoints;\n\n\t\t// :s\n\t\tif (endPoses.length != numJoints)\n\t\t\tendPoses.length = numJoints;\n\n\t\tfor (var j:number /*uint*/ = 0; j < this._skeletonAnimationNode.numInputs; ++j) {\n\t\t\tweight = this._blendWeights[j];\n\n\t\t\tif (!weight)\n\t\t\t\tcontinue;\n\n\t\t\tposes = this._inputs[j].getSkeletonPose(skeleton).jointPoses;\n\n\t\t\tif (!firstPose) {\n\t\t\t\tfirstPose = poses;\n\t\t\t\tfor (i = 0; i < numJoints; ++i) {\n\t\t\t\t\tendPose = endPoses[i];\n\n\t\t\t\t\tif (endPose == null)\n\t\t\t\t\t\tendPose = endPoses[i] = new JointPose();\n\n\t\t\t\t\tpose = poses[i];\n\t\t\t\t\tq = pose.orientation;\n\t\t\t\t\ttr = pose.translation;\n\n\t\t\t\t\tendQuat = endPose.orientation;\n\n\t\t\t\t\tendQuat.x = weight*q.x;\n\t\t\t\t\tendQuat.y = weight*q.y;\n\t\t\t\t\tendQuat.z = weight*q.z;\n\t\t\t\t\tendQuat.w = weight*q.w;\n\n\t\t\t\t\tendTr = endPose.translation;\n\t\t\t\t\tendTr.x = weight*tr.x;\n\t\t\t\t\tendTr.y = weight*tr.y;\n\t\t\t\t\tendTr.z = weight*tr.z;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tfor (i = 0; i < skeleton.numJoints; ++i) {\n\t\t\t\t\tendPose = endPoses[i];\n\t\t\t\t\tpose = poses[i];\n\n\t\t\t\t\tq = firstPose[i].orientation;\n\t\t\t\t\tx0 = q.x;\n\t\t\t\t\ty0 = q.y;\n\t\t\t\t\tz0 = q.z;\n\t\t\t\t\tw0 = q.w;\n\n\t\t\t\t\tq = pose.orientation;\n\t\t\t\t\ttr = pose.translation;\n\n\t\t\t\t\tx1 = q.x;\n\t\t\t\t\ty1 = q.y;\n\t\t\t\t\tz1 = q.z;\n\t\t\t\t\tw1 = q.w;\n\t\t\t\t\t// find shortest direction\n\t\t\t\t\tif (x0*x1 + y0*y1 + z0*z1 + w0*w1 < 0) {\n\t\t\t\t\t\tx1 = -x1;\n\t\t\t\t\t\ty1 = -y1;\n\t\t\t\t\t\tz1 = -z1;\n\t\t\t\t\t\tw1 = -w1;\n\t\t\t\t\t}\n\t\t\t\t\tendQuat = endPose.orientation;\n\t\t\t\t\tendQuat.x += weight*x1;\n\t\t\t\t\tendQuat.y += weight*y1;\n\t\t\t\t\tendQuat.z += weight*z1;\n\t\t\t\t\tendQuat.w += weight*w1;\n\n\t\t\t\t\tendTr = endPose.translation;\n\t\t\t\t\tendTr.x += weight*tr.x;\n\t\t\t\t\tendTr.y += weight*tr.y;\n\t\t\t\t\tendTr.z += weight*tr.z;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tfor (i = 0; i < skeleton.numJoints; ++i)\n\t\t\tendPoses[i].orientation.normalize();\n\t}\n}\n\nexport = SkeletonNaryLERPState;"]}
\ No newline at end of file
diff --git a/lib/animators/states/SkeletonNaryLERPState.ts b/lib/animators/states/SkeletonNaryLERPState.ts
new file mode 100644
index 000000000..16a84c27c
--- /dev/null
+++ b/lib/animators/states/SkeletonNaryLERPState.ts
@@ -0,0 +1,226 @@
+import Quaternion = require("awayjs-core/lib/core/geom/Quaternion");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+
+import JointPose = require("awayjs-renderergl/lib/animators/data/JointPose");
+import Skeleton = require("awayjs-renderergl/lib/animators/data/Skeleton");
+import SkeletonPose = require("awayjs-renderergl/lib/animators/data/SkeletonPose");
+import SkeletonNaryLERPNode = require("awayjs-renderergl/lib/animators/nodes/SkeletonNaryLERPNode");
+import AnimationStateBase = require("awayjs-renderergl/lib/animators/states/AnimationStateBase");
+import ISkeletonAnimationState = require("awayjs-renderergl/lib/animators/states/ISkeletonAnimationState");
+
+/**
+ *
+ */
+class SkeletonNaryLERPState extends AnimationStateBase implements ISkeletonAnimationState
+{
+ private _skeletonAnimationNode:SkeletonNaryLERPNode;
+ private _skeletonPose:SkeletonPose = new SkeletonPose();
+ private _skeletonPoseDirty:boolean = true;
+ private _blendWeights:Array = new Array();
+ private _inputs:Array = new Array();
+
+ constructor(animator:AnimatorBase, skeletonAnimationNode:SkeletonNaryLERPNode)
+ {
+ super(animator, skeletonAnimationNode);
+
+ this._skeletonAnimationNode = skeletonAnimationNode;
+
+ var i:number /*uint*/ = this._skeletonAnimationNode.numInputs;
+
+ while (i--)
+ this._inputs[i] = animator.getAnimationState(this._skeletonAnimationNode._iInputs[i]);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public phase(value:number)
+ {
+ this._skeletonPoseDirty = true;
+
+ this._pPositionDeltaDirty = true;
+
+ for (var j:number /*uint*/ = 0; j < this._skeletonAnimationNode.numInputs; ++j) {
+ if (this._blendWeights[j])
+ this._inputs[j].update(value);
+ }
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pUdateTime(time:number /*int*/)
+ {
+ for (var j:number /*uint*/ = 0; j < this._skeletonAnimationNode.numInputs; ++j) {
+ if (this._blendWeights[j])
+ this._inputs[j].update(time);
+ }
+
+ super._pUpdateTime(time);
+ }
+
+ /**
+ * Returns the current skeleton pose of the animation in the clip based on the internal playhead position.
+ */
+ public getSkeletonPose(skeleton:Skeleton):SkeletonPose
+ {
+ if (this._skeletonPoseDirty)
+ this.updateSkeletonPose(skeleton);
+
+ return this._skeletonPose;
+ }
+
+ /**
+ * Returns the blend weight of the skeleton aniamtion node that resides at the given input index.
+ *
+ * @param index The input index for which the skeleton animation node blend weight is requested.
+ */
+ public getBlendWeightAt(index:number /*uint*/):number
+ {
+ return this._blendWeights[index];
+ }
+
+ /**
+ * Sets the blend weight of the skeleton aniamtion node that resides at the given input index.
+ *
+ * @param index The input index on which the skeleton animation node blend weight is to be set.
+ * @param blendWeight The blend weight value to use for the given skeleton animation node index.
+ */
+ public setBlendWeightAt(index:number /*uint*/, blendWeight:number)
+ {
+ this._blendWeights[index] = blendWeight;
+
+ this._pPositionDeltaDirty = true;
+ this._skeletonPoseDirty = true;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pUpdatePositionDelta()
+ {
+ this._pPositionDeltaDirty = false;
+
+ var delta:Vector3D;
+ var weight:number;
+
+ this.positionDelta.x = 0;
+ this.positionDelta.y = 0;
+ this.positionDelta.z = 0;
+
+ for (var j:number /*uint*/ = 0; j < this._skeletonAnimationNode.numInputs; ++j) {
+ weight = this._blendWeights[j];
+
+ if (weight) {
+ delta = this._inputs[j].positionDelta;
+ this.positionDelta.x += weight*delta.x;
+ this.positionDelta.y += weight*delta.y;
+ this.positionDelta.z += weight*delta.z;
+ }
+ }
+ }
+
+ /**
+ * Updates the output skeleton pose of the node based on the blend weight values given to the input nodes.
+ *
+ * @param skeleton The skeleton used by the animator requesting the ouput pose.
+ */
+ private updateSkeletonPose(skeleton:Skeleton)
+ {
+ this._skeletonPoseDirty = false;
+
+ var weight:number;
+ var endPoses:Array = this._skeletonPose.jointPoses;
+ var poses:Array;
+ var endPose:JointPose, pose:JointPose;
+ var endTr:Vector3D, tr:Vector3D;
+ var endQuat:Quaternion, q:Quaternion;
+ var firstPose:Array;
+ var i:number /*uint*/;
+ var w0:number, x0:number, y0:number, z0:number;
+ var w1:number, x1:number, y1:number, z1:number;
+ var numJoints:number /*uint*/ = skeleton.numJoints;
+
+ // :s
+ if (endPoses.length != numJoints)
+ endPoses.length = numJoints;
+
+ for (var j:number /*uint*/ = 0; j < this._skeletonAnimationNode.numInputs; ++j) {
+ weight = this._blendWeights[j];
+
+ if (!weight)
+ continue;
+
+ poses = this._inputs[j].getSkeletonPose(skeleton).jointPoses;
+
+ if (!firstPose) {
+ firstPose = poses;
+ for (i = 0; i < numJoints; ++i) {
+ endPose = endPoses[i];
+
+ if (endPose == null)
+ endPose = endPoses[i] = new JointPose();
+
+ pose = poses[i];
+ q = pose.orientation;
+ tr = pose.translation;
+
+ endQuat = endPose.orientation;
+
+ endQuat.x = weight*q.x;
+ endQuat.y = weight*q.y;
+ endQuat.z = weight*q.z;
+ endQuat.w = weight*q.w;
+
+ endTr = endPose.translation;
+ endTr.x = weight*tr.x;
+ endTr.y = weight*tr.y;
+ endTr.z = weight*tr.z;
+ }
+ } else {
+ for (i = 0; i < skeleton.numJoints; ++i) {
+ endPose = endPoses[i];
+ pose = poses[i];
+
+ q = firstPose[i].orientation;
+ x0 = q.x;
+ y0 = q.y;
+ z0 = q.z;
+ w0 = q.w;
+
+ q = pose.orientation;
+ tr = pose.translation;
+
+ x1 = q.x;
+ y1 = q.y;
+ z1 = q.z;
+ w1 = q.w;
+ // find shortest direction
+ if (x0*x1 + y0*y1 + z0*z1 + w0*w1 < 0) {
+ x1 = -x1;
+ y1 = -y1;
+ z1 = -z1;
+ w1 = -w1;
+ }
+ endQuat = endPose.orientation;
+ endQuat.x += weight*x1;
+ endQuat.y += weight*y1;
+ endQuat.z += weight*z1;
+ endQuat.w += weight*w1;
+
+ endTr = endPose.translation;
+ endTr.x += weight*tr.x;
+ endTr.y += weight*tr.y;
+ endTr.z += weight*tr.z;
+ }
+ }
+ }
+
+ for (i = 0; i < skeleton.numJoints; ++i)
+ endPoses[i].orientation.normalize();
+ }
+}
+
+export = SkeletonNaryLERPState;
\ No newline at end of file
diff --git a/lib/animators/states/VertexClipState.js b/lib/animators/states/VertexClipState.js
new file mode 100755
index 000000000..fdace4ecd
--- /dev/null
+++ b/lib/animators/states/VertexClipState.js
@@ -0,0 +1,65 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var AnimationClipState = require("awayjs-renderergl/lib/animators/states/AnimationClipState");
+/**
+ *
+ */
+var VertexClipState = (function (_super) {
+ __extends(VertexClipState, _super);
+ function VertexClipState(animator, vertexClipNode) {
+ _super.call(this, animator, vertexClipNode);
+ this._vertexClipNode = vertexClipNode;
+ this._frames = this._vertexClipNode.frames;
+ }
+ Object.defineProperty(VertexClipState.prototype, "currentGeometry", {
+ /**
+ * @inheritDoc
+ */
+ get: function () {
+ if (this._pFramesDirty)
+ this._pUpdateFrames();
+ return this._currentGeometry;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(VertexClipState.prototype, "nextGeometry", {
+ /**
+ * @inheritDoc
+ */
+ get: function () {
+ if (this._pFramesDirty)
+ this._pUpdateFrames();
+ return this._nextGeometry;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ VertexClipState.prototype._pUpdateFrames = function () {
+ _super.prototype._pUpdateFrames.call(this);
+ this._currentGeometry = this._frames[this._pCurrentFrame];
+ if (this._vertexClipNode.looping && this._pNextFrame >= this._vertexClipNode.lastFrame) {
+ this._nextGeometry = this._frames[0];
+ this._pAnimator.dispatchCycleEvent();
+ }
+ else
+ this._nextGeometry = this._frames[this._pNextFrame];
+ };
+ /**
+ * @inheritDoc
+ */
+ VertexClipState.prototype._pUpdatePositionDelta = function () {
+ //TODO:implement positiondelta functionality for vertex animations
+ };
+ return VertexClipState;
+})(AnimationClipState);
+module.exports = VertexClipState;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy9zdGF0ZXMvdmVydGV4Y2xpcHN0YXRlLnRzIl0sIm5hbWVzIjpbIlZlcnRleENsaXBTdGF0ZSIsIlZlcnRleENsaXBTdGF0ZS5jb25zdHJ1Y3RvciIsIlZlcnRleENsaXBTdGF0ZS5jdXJyZW50R2VvbWV0cnkiLCJWZXJ0ZXhDbGlwU3RhdGUubmV4dEdlb21ldHJ5IiwiVmVydGV4Q2xpcFN0YXRlLl9wVXBkYXRlRnJhbWVzIiwiVmVydGV4Q2xpcFN0YXRlLl9wVXBkYXRlUG9zaXRpb25EZWx0YSJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBTUEsSUFBTyxrQkFBa0IsV0FBYywyREFBMkQsQ0FBQyxDQUFDO0FBR3BHLEFBR0E7O0dBREc7SUFDRyxlQUFlO0lBQVNBLFVBQXhCQSxlQUFlQSxVQUEyQkE7SUE2Qi9DQSxTQTdCS0EsZUFBZUEsQ0E2QlJBLFFBQXFCQSxFQUFFQSxjQUE2QkE7UUFFL0RDLGtCQUFNQSxRQUFRQSxFQUFFQSxjQUFjQSxDQUFDQSxDQUFDQTtRQUVoQ0EsSUFBSUEsQ0FBQ0EsZUFBZUEsR0FBR0EsY0FBY0EsQ0FBQ0E7UUFDdENBLElBQUlBLENBQUNBLE9BQU9BLEdBQUdBLElBQUlBLENBQUNBLGVBQWVBLENBQUNBLE1BQU1BLENBQUNBO0lBQzVDQSxDQUFDQTtJQXpCREQsc0JBQVdBLDRDQUFlQTtRQUgxQkE7O1dBRUdBO2FBQ0hBO1lBRUNFLEVBQUVBLENBQUNBLENBQUNBLElBQUlBLENBQUNBLGFBQWFBLENBQUNBO2dCQUN0QkEsSUFBSUEsQ0FBQ0EsY0FBY0EsRUFBRUEsQ0FBQ0E7WUFFdkJBLE1BQU1BLENBQUNBLElBQUlBLENBQUNBLGdCQUFnQkEsQ0FBQ0E7UUFDOUJBLENBQUNBOzs7T0FBQUY7SUFLREEsc0JBQVdBLHlDQUFZQTtRQUh2QkE7O1dBRUdBO2FBQ0hBO1lBRUNHLEVBQUVBLENBQUNBLENBQUNBLElBQUlBLENBQUNBLGFBQWFBLENBQUNBO2dCQUN0QkEsSUFBSUEsQ0FBQ0EsY0FBY0EsRUFBRUEsQ0FBQ0E7WUFFdkJBLE1BQU1BLENBQUNBLElBQUlBLENBQUNBLGFBQWFBLENBQUNBO1FBQzNCQSxDQUFDQTs7O09BQUFIO0lBVURBOztPQUVHQTtJQUNJQSx3Q0FBY0EsR0FBckJBO1FBRUNJLGdCQUFLQSxDQUFDQSxjQUFjQSxXQUFFQSxDQUFDQTtRQUV2QkEsSUFBSUEsQ0FBQ0EsZ0JBQWdCQSxHQUFHQSxJQUFJQSxDQUFDQSxPQUFPQSxDQUFDQSxJQUFJQSxDQUFDQSxjQUFjQSxDQUFDQSxDQUFDQTtRQUUxREEsRUFBRUEsQ0FBQ0EsQ0FBQ0EsSUFBSUEsQ0FBQ0EsZUFBZUEsQ0FBQ0EsT0FBT0EsSUFBSUEsSUFBSUEsQ0FBQ0EsV0FBV0EsSUFBSUEsSUFBSUEsQ0FBQ0EsZUFBZUEsQ0FBQ0EsU0FBU0EsQ0FBQ0EsQ0FBQ0EsQ0FBQ0E7WUFDeEZBLElBQUlBLENBQUNBLGFBQWFBLEdBQUdBLElBQUlBLENBQUNBLE9BQU9BLENBQUNBLENBQUNBLENBQUNBLENBQUNBO1lBQ25CQSxJQUFJQSxDQUFDQSxVQUFXQSxDQUFDQSxrQkFBa0JBLEVBQUVBLENBQUNBO1FBQ3pEQSxDQUFDQTtRQUFDQSxJQUFJQTtZQUNMQSxJQUFJQSxDQUFDQSxhQUFhQSxHQUFHQSxJQUFJQSxDQUFDQSxPQUFPQSxDQUFDQSxJQUFJQSxDQUFDQSxXQUFXQSxDQUFDQSxDQUFDQTtJQUN0REEsQ0FBQ0E7SUFFREo7O09BRUdBO0lBQ0lBLCtDQUFxQkEsR0FBNUJBO1FBRUNLLGtFQUFrRUE7SUFDbkVBLENBQUNBO0lBQ0ZMLHNCQUFDQTtBQUFEQSxDQTVEQSxBQTREQ0EsRUE1RDZCLGtCQUFrQixFQTREL0M7QUFFRCxBQUF5QixpQkFBaEIsZUFBZSxDQUFDIiwiZmlsZSI6ImFuaW1hdG9ycy9zdGF0ZXMvVmVydGV4Q2xpcFN0YXRlLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2JiYXRlbWFuL1dlYnN0b3JtUHJvamVjdHMvYXdheWpzLXJlbmRlcmVyZ2wvIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEdlb21ldHJ5XHRcdFx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvY29yZS9iYXNlL0dlb21ldHJ5XCIpO1xuXG5pbXBvcnQgQW5pbWF0b3JCYXNlXHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2FuaW1hdG9ycy9BbmltYXRvckJhc2VcIik7XG5cbmltcG9ydCBWZXJ0ZXhBbmltYXRvclx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL1ZlcnRleEFuaW1hdG9yXCIpO1xuaW1wb3J0IFZlcnRleENsaXBOb2RlXHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvbm9kZXMvVmVydGV4Q2xpcE5vZGVcIik7XG5pbXBvcnQgQW5pbWF0aW9uQ2xpcFN0YXRlXHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL3N0YXRlcy9BbmltYXRpb25DbGlwU3RhdGVcIik7XG5pbXBvcnQgSVZlcnRleEFuaW1hdGlvblN0YXRlXHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXJlbmRlcmVyZ2wvbGliL2FuaW1hdG9ycy9zdGF0ZXMvSVZlcnRleEFuaW1hdGlvblN0YXRlXCIpO1xuXG4vKipcbiAqXG4gKi9cbmNsYXNzIFZlcnRleENsaXBTdGF0ZSBleHRlbmRzIEFuaW1hdGlvbkNsaXBTdGF0ZSBpbXBsZW1lbnRzIElWZXJ0ZXhBbmltYXRpb25TdGF0ZVxue1xuXHRwcml2YXRlIF9mcmFtZXM6QXJyYXk8R2VvbWV0cnk+O1xuXHRwcml2YXRlIF92ZXJ0ZXhDbGlwTm9kZTpWZXJ0ZXhDbGlwTm9kZTtcblx0cHJpdmF0ZSBfY3VycmVudEdlb21ldHJ5Okdlb21ldHJ5O1xuXHRwcml2YXRlIF9uZXh0R2VvbWV0cnk6R2VvbWV0cnk7XG5cblx0LyoqXG5cdCAqIEBpbmhlcml0RG9jXG5cdCAqL1xuXHRwdWJsaWMgZ2V0IGN1cnJlbnRHZW9tZXRyeSgpOkdlb21ldHJ5XG5cdHtcblx0XHRpZiAodGhpcy5fcEZyYW1lc0RpcnR5KVxuXHRcdFx0dGhpcy5fcFVwZGF0ZUZyYW1lcygpO1xuXG5cdFx0cmV0dXJuIHRoaXMuX2N1cnJlbnRHZW9tZXRyeTtcblx0fVxuXG5cdC8qKlxuXHQgKiBAaW5oZXJpdERvY1xuXHQgKi9cblx0cHVibGljIGdldCBuZXh0R2VvbWV0cnkoKTpHZW9tZXRyeVxuXHR7XG5cdFx0aWYgKHRoaXMuX3BGcmFtZXNEaXJ0eSlcblx0XHRcdHRoaXMuX3BVcGRhdGVGcmFtZXMoKTtcblxuXHRcdHJldHVybiB0aGlzLl9uZXh0R2VvbWV0cnk7XG5cdH1cblxuXHRjb25zdHJ1Y3RvcihhbmltYXRvcjpBbmltYXRvckJhc2UsIHZlcnRleENsaXBOb2RlOlZlcnRleENsaXBOb2RlKVxuXHR7XG5cdFx0c3VwZXIoYW5pbWF0b3IsIHZlcnRleENsaXBOb2RlKTtcblxuXHRcdHRoaXMuX3ZlcnRleENsaXBOb2RlID0gdmVydGV4Q2xpcE5vZGU7XG5cdFx0dGhpcy5fZnJhbWVzID0gdGhpcy5fdmVydGV4Q2xpcE5vZGUuZnJhbWVzO1xuXHR9XG5cblx0LyoqXG5cdCAqIEBpbmhlcml0RG9jXG5cdCAqL1xuXHRwdWJsaWMgX3BVcGRhdGVGcmFtZXMoKVxuXHR7XG5cdFx0c3VwZXIuX3BVcGRhdGVGcmFtZXMoKTtcblxuXHRcdHRoaXMuX2N1cnJlbnRHZW9tZXRyeSA9IHRoaXMuX2ZyYW1lc1t0aGlzLl9wQ3VycmVudEZyYW1lXTtcblxuXHRcdGlmICh0aGlzLl92ZXJ0ZXhDbGlwTm9kZS5sb29waW5nICYmIHRoaXMuX3BOZXh0RnJhbWUgPj0gdGhpcy5fdmVydGV4Q2xpcE5vZGUubGFzdEZyYW1lKSB7XG5cdFx0XHR0aGlzLl9uZXh0R2VvbWV0cnkgPSB0aGlzLl9mcmFtZXNbMF07XG5cdFx0XHQoPFZlcnRleEFuaW1hdG9yPiB0aGlzLl9wQW5pbWF0b3IpLmRpc3BhdGNoQ3ljbGVFdmVudCgpO1xuXHRcdH0gZWxzZVxuXHRcdFx0dGhpcy5fbmV4dEdlb21ldHJ5ID0gdGhpcy5fZnJhbWVzW3RoaXMuX3BOZXh0RnJhbWVdO1xuXHR9XG5cblx0LyoqXG5cdCAqIEBpbmhlcml0RG9jXG5cdCAqL1xuXHRwdWJsaWMgX3BVcGRhdGVQb3NpdGlvbkRlbHRhKClcblx0e1xuXHRcdC8vVE9ETzppbXBsZW1lbnQgcG9zaXRpb25kZWx0YSBmdW5jdGlvbmFsaXR5IGZvciB2ZXJ0ZXggYW5pbWF0aW9uc1xuXHR9XG59XG5cbmV4cG9ydCA9IFZlcnRleENsaXBTdGF0ZTsiXX0=
\ No newline at end of file
diff --git a/lib/animators/states/VertexClipState.ts b/lib/animators/states/VertexClipState.ts
new file mode 100644
index 000000000..8e235d387
--- /dev/null
+++ b/lib/animators/states/VertexClipState.ts
@@ -0,0 +1,75 @@
+import Geometry = require("awayjs-core/lib/core/base/Geometry");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+
+import VertexAnimator = require("awayjs-renderergl/lib/animators/VertexAnimator");
+import VertexClipNode = require("awayjs-renderergl/lib/animators/nodes/VertexClipNode");
+import AnimationClipState = require("awayjs-renderergl/lib/animators/states/AnimationClipState");
+import IVertexAnimationState = require("awayjs-renderergl/lib/animators/states/IVertexAnimationState");
+
+/**
+ *
+ */
+class VertexClipState extends AnimationClipState implements IVertexAnimationState
+{
+ private _frames:Array;
+ private _vertexClipNode:VertexClipNode;
+ private _currentGeometry:Geometry;
+ private _nextGeometry:Geometry;
+
+ /**
+ * @inheritDoc
+ */
+ public get currentGeometry():Geometry
+ {
+ if (this._pFramesDirty)
+ this._pUpdateFrames();
+
+ return this._currentGeometry;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public get nextGeometry():Geometry
+ {
+ if (this._pFramesDirty)
+ this._pUpdateFrames();
+
+ return this._nextGeometry;
+ }
+
+ constructor(animator:AnimatorBase, vertexClipNode:VertexClipNode)
+ {
+ super(animator, vertexClipNode);
+
+ this._vertexClipNode = vertexClipNode;
+ this._frames = this._vertexClipNode.frames;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pUpdateFrames()
+ {
+ super._pUpdateFrames();
+
+ this._currentGeometry = this._frames[this._pCurrentFrame];
+
+ if (this._vertexClipNode.looping && this._pNextFrame >= this._vertexClipNode.lastFrame) {
+ this._nextGeometry = this._frames[0];
+ ( this._pAnimator).dispatchCycleEvent();
+ } else
+ this._nextGeometry = this._frames[this._pNextFrame];
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pUpdatePositionDelta()
+ {
+ //TODO:implement positiondelta functionality for vertex animations
+ }
+}
+
+export = VertexClipState;
\ No newline at end of file
diff --git a/lib/animators/transitions/CrossfadeTransition.js b/lib/animators/transitions/CrossfadeTransition.js
new file mode 100755
index 000000000..39a6500f2
--- /dev/null
+++ b/lib/animators/transitions/CrossfadeTransition.js
@@ -0,0 +1,22 @@
+var CrossfadeTransitionNode = require("awayjs-renderergl/lib/animators/transitions/CrossfadeTransitionNode");
+/**
+ *
+ */
+var CrossfadeTransition = (function () {
+ function CrossfadeTransition(blendSpeed) {
+ this.blendSpeed = 0.5;
+ this.blendSpeed = blendSpeed;
+ }
+ CrossfadeTransition.prototype.getAnimationNode = function (animator, startNode, endNode, startBlend /*int*/) {
+ var crossFadeTransitionNode = new CrossfadeTransitionNode();
+ crossFadeTransitionNode.inputA = startNode;
+ crossFadeTransitionNode.inputB = endNode;
+ crossFadeTransitionNode.blendSpeed = this.blendSpeed;
+ crossFadeTransitionNode.startBlend = startBlend;
+ return crossFadeTransitionNode;
+ };
+ return CrossfadeTransition;
+})();
+module.exports = CrossfadeTransition;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy90cmFuc2l0aW9ucy9jcm9zc2ZhZGV0cmFuc2l0aW9uLnRzIl0sIm5hbWVzIjpbIkNyb3NzZmFkZVRyYW5zaXRpb24iLCJDcm9zc2ZhZGVUcmFuc2l0aW9uLmNvbnN0cnVjdG9yIiwiQ3Jvc3NmYWRlVHJhbnNpdGlvbi5nZXRBbmltYXRpb25Ob2RlIl0sIm1hcHBpbmdzIjoiQUFJQSxJQUFPLHVCQUF1QixXQUFhLHFFQUFxRSxDQUFDLENBQUM7QUFHbEgsQUFHQTs7R0FERztJQUNHLG1CQUFtQjtJQUl4QkEsU0FKS0EsbUJBQW1CQSxDQUlaQSxVQUFpQkE7UUFGdEJDLGVBQVVBLEdBQVVBLEdBQUdBLENBQUNBO1FBSTlCQSxJQUFJQSxDQUFDQSxVQUFVQSxHQUFHQSxVQUFVQSxDQUFDQTtJQUM5QkEsQ0FBQ0E7SUFFTUQsOENBQWdCQSxHQUF2QkEsVUFBd0JBLFFBQXFCQSxFQUFFQSxTQUEyQkEsRUFBRUEsT0FBeUJBLEVBQUVBLFVBQVVBLENBQVFBLE9BQURBLEFBQVFBO1FBRS9IRSxJQUFJQSx1QkFBdUJBLEdBQTJCQSxJQUFJQSx1QkFBdUJBLEVBQUVBLENBQUNBO1FBQ3BGQSx1QkFBdUJBLENBQUNBLE1BQU1BLEdBQUdBLFNBQVNBLENBQUNBO1FBQzNDQSx1QkFBdUJBLENBQUNBLE1BQU1BLEdBQUdBLE9BQU9BLENBQUNBO1FBQ3pDQSx1QkFBdUJBLENBQUNBLFVBQVVBLEdBQUdBLElBQUlBLENBQUNBLFVBQVVBLENBQUNBO1FBQ3JEQSx1QkFBdUJBLENBQUNBLFVBQVVBLEdBQUdBLFVBQVVBLENBQUNBO1FBRWhEQSxNQUFNQSxDQUFxQkEsdUJBQXVCQSxDQUFDQTtJQUNwREEsQ0FBQ0E7SUFDRkYsMEJBQUNBO0FBQURBLENBbkJBLEFBbUJDQSxJQUFBO0FBRUQsQUFBNkIsaUJBQXBCLG1CQUFtQixDQUFDIiwiZmlsZSI6ImFuaW1hdG9ycy90cmFuc2l0aW9ucy9Dcm9zc2ZhZGVUcmFuc2l0aW9uLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2JiYXRlbWFuL1dlYnN0b3JtUHJvamVjdHMvYXdheWpzLXJlbmRlcmVyZ2wvIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEFuaW1hdGlvbk5vZGVCYXNlXHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvYW5pbWF0b3JzL25vZGVzL0FuaW1hdGlvbk5vZGVCYXNlXCIpO1xuXG5pbXBvcnQgQW5pbWF0b3JCYXNlXHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2FuaW1hdG9ycy9BbmltYXRvckJhc2VcIik7XG5cbmltcG9ydCBDcm9zc2ZhZGVUcmFuc2l0aW9uTm9kZVx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvdHJhbnNpdGlvbnMvQ3Jvc3NmYWRlVHJhbnNpdGlvbk5vZGVcIik7XG5pbXBvcnQgSUFuaW1hdGlvblRyYW5zaXRpb25cdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvdHJhbnNpdGlvbnMvSUFuaW1hdGlvblRyYW5zaXRpb25cIik7XG5cbi8qKlxuICpcbiAqL1xuY2xhc3MgQ3Jvc3NmYWRlVHJhbnNpdGlvbiBpbXBsZW1lbnRzIElBbmltYXRpb25UcmFuc2l0aW9uXG57XG5cdHB1YmxpYyBibGVuZFNwZWVkOm51bWJlciA9IDAuNTtcblxuXHRjb25zdHJ1Y3RvcihibGVuZFNwZWVkOm51bWJlcilcblx0e1xuXHRcdHRoaXMuYmxlbmRTcGVlZCA9IGJsZW5kU3BlZWQ7XG5cdH1cblxuXHRwdWJsaWMgZ2V0QW5pbWF0aW9uTm9kZShhbmltYXRvcjpBbmltYXRvckJhc2UsIHN0YXJ0Tm9kZTpBbmltYXRpb25Ob2RlQmFzZSwgZW5kTm9kZTpBbmltYXRpb25Ob2RlQmFzZSwgc3RhcnRCbGVuZDpudW1iZXIgLyppbnQqLyk6QW5pbWF0aW9uTm9kZUJhc2Vcblx0e1xuXHRcdHZhciBjcm9zc0ZhZGVUcmFuc2l0aW9uTm9kZTpDcm9zc2ZhZGVUcmFuc2l0aW9uTm9kZSA9IG5ldyBDcm9zc2ZhZGVUcmFuc2l0aW9uTm9kZSgpO1xuXHRcdGNyb3NzRmFkZVRyYW5zaXRpb25Ob2RlLmlucHV0QSA9IHN0YXJ0Tm9kZTtcblx0XHRjcm9zc0ZhZGVUcmFuc2l0aW9uTm9kZS5pbnB1dEIgPSBlbmROb2RlO1xuXHRcdGNyb3NzRmFkZVRyYW5zaXRpb25Ob2RlLmJsZW5kU3BlZWQgPSB0aGlzLmJsZW5kU3BlZWQ7XG5cdFx0Y3Jvc3NGYWRlVHJhbnNpdGlvbk5vZGUuc3RhcnRCbGVuZCA9IHN0YXJ0QmxlbmQ7XG5cblx0XHRyZXR1cm4gPEFuaW1hdGlvbk5vZGVCYXNlPiBjcm9zc0ZhZGVUcmFuc2l0aW9uTm9kZTtcblx0fVxufVxuXG5leHBvcnQgPSBDcm9zc2ZhZGVUcmFuc2l0aW9uOyJdfQ==
\ No newline at end of file
diff --git a/lib/animators/transitions/CrossfadeTransition.ts b/lib/animators/transitions/CrossfadeTransition.ts
new file mode 100644
index 000000000..735490b90
--- /dev/null
+++ b/lib/animators/transitions/CrossfadeTransition.ts
@@ -0,0 +1,32 @@
+import AnimationNodeBase = require("awayjs-core/lib/animators/nodes/AnimationNodeBase");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+
+import CrossfadeTransitionNode = require("awayjs-renderergl/lib/animators/transitions/CrossfadeTransitionNode");
+import IAnimationTransition = require("awayjs-renderergl/lib/animators/transitions/IAnimationTransition");
+
+/**
+ *
+ */
+class CrossfadeTransition implements IAnimationTransition
+{
+ public blendSpeed:number = 0.5;
+
+ constructor(blendSpeed:number)
+ {
+ this.blendSpeed = blendSpeed;
+ }
+
+ public getAnimationNode(animator:AnimatorBase, startNode:AnimationNodeBase, endNode:AnimationNodeBase, startBlend:number /*int*/):AnimationNodeBase
+ {
+ var crossFadeTransitionNode:CrossfadeTransitionNode = new CrossfadeTransitionNode();
+ crossFadeTransitionNode.inputA = startNode;
+ crossFadeTransitionNode.inputB = endNode;
+ crossFadeTransitionNode.blendSpeed = this.blendSpeed;
+ crossFadeTransitionNode.startBlend = startBlend;
+
+ return crossFadeTransitionNode;
+ }
+}
+
+export = CrossfadeTransition;
\ No newline at end of file
diff --git a/lib/animators/transitions/CrossfadeTransitionNode.js b/lib/animators/transitions/CrossfadeTransitionNode.js
new file mode 100755
index 000000000..f0ce26b4d
--- /dev/null
+++ b/lib/animators/transitions/CrossfadeTransitionNode.js
@@ -0,0 +1,25 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var SkeletonBinaryLERPNode = require("awayjs-renderergl/lib/animators/nodes/SkeletonBinaryLERPNode");
+var CrossfadeTransitionState = require("awayjs-renderergl/lib/animators/transitions/CrossfadeTransitionState");
+/**
+ * A skeleton animation node that uses two animation node inputs to blend a lineraly interpolated output of a skeleton pose.
+ */
+var CrossfadeTransitionNode = (function (_super) {
+ __extends(CrossfadeTransitionNode, _super);
+ /**
+ * Creates a new CrossfadeTransitionNode
object.
+ */
+ function CrossfadeTransitionNode() {
+ _super.call(this);
+ this._pStateClass = CrossfadeTransitionState;
+ }
+ return CrossfadeTransitionNode;
+})(SkeletonBinaryLERPNode);
+module.exports = CrossfadeTransitionNode;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy90cmFuc2l0aW9ucy9jcm9zc2ZhZGV0cmFuc2l0aW9ubm9kZS50cyJdLCJuYW1lcyI6WyJDcm9zc2ZhZGVUcmFuc2l0aW9uTm9kZSIsIkNyb3NzZmFkZVRyYW5zaXRpb25Ob2RlLmNvbnN0cnVjdG9yIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxJQUFPLHNCQUFzQixXQUFhLDhEQUE4RCxDQUFDLENBQUM7QUFDMUcsSUFBTyx3QkFBd0IsV0FBYSxzRUFBc0UsQ0FBQyxDQUFDO0FBRXBILEFBR0E7O0dBREc7SUFDRyx1QkFBdUI7SUFBU0EsVUFBaENBLHVCQUF1QkEsVUFBK0JBO0lBTTNEQTs7T0FFR0E7SUFDSEEsU0FUS0EsdUJBQXVCQTtRQVczQkMsaUJBQU9BLENBQUNBO1FBRVJBLElBQUlBLENBQUNBLFlBQVlBLEdBQUdBLHdCQUF3QkEsQ0FBQ0E7SUFDOUNBLENBQUNBO0lBQ0ZELDhCQUFDQTtBQUFEQSxDQWZBLEFBZUNBLEVBZnFDLHNCQUFzQixFQWUzRDtBQUVELEFBQWlDLGlCQUF4Qix1QkFBdUIsQ0FBQyIsImZpbGUiOiJhbmltYXRvcnMvdHJhbnNpdGlvbnMvQ3Jvc3NmYWRlVHJhbnNpdGlvbk5vZGUuanMiLCJzb3VyY2VSb290IjoiL1VzZXJzL3JvYmJhdGVtYW4vV2Vic3Rvcm1Qcm9qZWN0cy9hd2F5anMtcmVuZGVyZXJnbC8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgU2tlbGV0b25CaW5hcnlMRVJQTm9kZVx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvbm9kZXMvU2tlbGV0b25CaW5hcnlMRVJQTm9kZVwiKTtcbmltcG9ydCBDcm9zc2ZhZGVUcmFuc2l0aW9uU3RhdGVcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL3RyYW5zaXRpb25zL0Nyb3NzZmFkZVRyYW5zaXRpb25TdGF0ZVwiKTtcblxuLyoqXG4gKiBBIHNrZWxldG9uIGFuaW1hdGlvbiBub2RlIHRoYXQgdXNlcyB0d28gYW5pbWF0aW9uIG5vZGUgaW5wdXRzIHRvIGJsZW5kIGEgbGluZXJhbHkgaW50ZXJwb2xhdGVkIG91dHB1dCBvZiBhIHNrZWxldG9uIHBvc2UuXG4gKi9cbmNsYXNzIENyb3NzZmFkZVRyYW5zaXRpb25Ob2RlIGV4dGVuZHMgU2tlbGV0b25CaW5hcnlMRVJQTm9kZVxue1xuXHRwdWJsaWMgYmxlbmRTcGVlZDpudW1iZXI7XG5cblx0cHVibGljIHN0YXJ0QmxlbmQ6bnVtYmVyIC8qaW50Ki87XG5cblx0LyoqXG5cdCAqIENyZWF0ZXMgYSBuZXcgPGNvZGU+Q3Jvc3NmYWRlVHJhbnNpdGlvbk5vZGU8L2NvZGU+IG9iamVjdC5cblx0ICovXG5cdGNvbnN0cnVjdG9yKClcblx0e1xuXHRcdHN1cGVyKCk7XG5cblx0XHR0aGlzLl9wU3RhdGVDbGFzcyA9IENyb3NzZmFkZVRyYW5zaXRpb25TdGF0ZTtcblx0fVxufVxuXG5leHBvcnQgPSBDcm9zc2ZhZGVUcmFuc2l0aW9uTm9kZTsiXX0=
\ No newline at end of file
diff --git a/lib/animators/transitions/CrossfadeTransitionNode.ts b/lib/animators/transitions/CrossfadeTransitionNode.ts
new file mode 100644
index 000000000..129b27a6d
--- /dev/null
+++ b/lib/animators/transitions/CrossfadeTransitionNode.ts
@@ -0,0 +1,24 @@
+import SkeletonBinaryLERPNode = require("awayjs-renderergl/lib/animators/nodes/SkeletonBinaryLERPNode");
+import CrossfadeTransitionState = require("awayjs-renderergl/lib/animators/transitions/CrossfadeTransitionState");
+
+/**
+ * A skeleton animation node that uses two animation node inputs to blend a lineraly interpolated output of a skeleton pose.
+ */
+class CrossfadeTransitionNode extends SkeletonBinaryLERPNode
+{
+ public blendSpeed:number;
+
+ public startBlend:number /*int*/;
+
+ /**
+ * Creates a new CrossfadeTransitionNode
object.
+ */
+ constructor()
+ {
+ super();
+
+ this._pStateClass = CrossfadeTransitionState;
+ }
+}
+
+export = CrossfadeTransitionNode;
\ No newline at end of file
diff --git a/lib/animators/transitions/CrossfadeTransitionState.js b/lib/animators/transitions/CrossfadeTransitionState.js
new file mode 100755
index 000000000..c55963505
--- /dev/null
+++ b/lib/animators/transitions/CrossfadeTransitionState.js
@@ -0,0 +1,35 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var SkeletonBinaryLERPState = require("awayjs-renderergl/lib/animators/states/SkeletonBinaryLERPState");
+var AnimationStateEvent = require("awayjs-renderergl/lib/events/AnimationStateEvent");
+/**
+ *
+ */
+var CrossfadeTransitionState = (function (_super) {
+ __extends(CrossfadeTransitionState, _super);
+ function CrossfadeTransitionState(animator, skeletonAnimationNode) {
+ _super.call(this, animator, skeletonAnimationNode);
+ this._crossfadeTransitionNode = skeletonAnimationNode;
+ }
+ /**
+ * @inheritDoc
+ */
+ CrossfadeTransitionState.prototype._pUpdateTime = function (time /*int*/) {
+ this.blendWeight = Math.abs(time - this._crossfadeTransitionNode.startBlend) / (1000 * this._crossfadeTransitionNode.blendSpeed);
+ if (this.blendWeight >= 1) {
+ this.blendWeight = 1;
+ if (this._animationStateTransitionComplete == null)
+ this._animationStateTransitionComplete = new AnimationStateEvent(AnimationStateEvent.TRANSITION_COMPLETE, this._pAnimator, this, this._crossfadeTransitionNode);
+ this._crossfadeTransitionNode.dispatchEvent(this._animationStateTransitionComplete);
+ }
+ _super.prototype._pUpdateTime.call(this, time);
+ };
+ return CrossfadeTransitionState;
+})(SkeletonBinaryLERPState);
+module.exports = CrossfadeTransitionState;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy90cmFuc2l0aW9ucy9jcm9zc2ZhZGV0cmFuc2l0aW9uc3RhdGUudHMiXSwibmFtZXMiOlsiQ3Jvc3NmYWRlVHJhbnNpdGlvblN0YXRlIiwiQ3Jvc3NmYWRlVHJhbnNpdGlvblN0YXRlLmNvbnN0cnVjdG9yIiwiQ3Jvc3NmYWRlVHJhbnNpdGlvblN0YXRlLl9wVXBkYXRlVGltZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBR0EsSUFBTyx1QkFBdUIsV0FBYSxnRUFBZ0UsQ0FBQyxDQUFDO0FBRTdHLElBQU8sbUJBQW1CLFdBQWMsa0RBQWtELENBQUMsQ0FBQztBQUU1RixBQUdBOztHQURHO0lBQ0csd0JBQXdCO0lBQVNBLFVBQWpDQSx3QkFBd0JBLFVBQWdDQTtJQUs3REEsU0FMS0Esd0JBQXdCQSxDQUtqQkEsUUFBcUJBLEVBQUVBLHFCQUE2Q0E7UUFFL0VDLGtCQUFNQSxRQUFRQSxFQUEyQkEscUJBQXFCQSxDQUFDQSxDQUFDQTtRQUVoRUEsSUFBSUEsQ0FBQ0Esd0JBQXdCQSxHQUFHQSxxQkFBcUJBLENBQUNBO0lBQ3ZEQSxDQUFDQTtJQUVERDs7T0FFR0E7SUFDSUEsK0NBQVlBLEdBQW5CQSxVQUFvQkEsSUFBSUEsQ0FBUUEsT0FBREEsQUFBUUE7UUFFdENFLElBQUlBLENBQUNBLFdBQVdBLEdBQUdBLElBQUlBLENBQUNBLEdBQUdBLENBQUNBLElBQUlBLEdBQUdBLElBQUlBLENBQUNBLHdCQUF3QkEsQ0FBQ0EsVUFBVUEsQ0FBQ0EsR0FBQ0EsQ0FBQ0EsSUFBSUEsR0FBQ0EsSUFBSUEsQ0FBQ0Esd0JBQXdCQSxDQUFDQSxVQUFVQSxDQUFDQSxDQUFDQTtRQUU3SEEsRUFBRUEsQ0FBQ0EsQ0FBQ0EsSUFBSUEsQ0FBQ0EsV0FBV0EsSUFBSUEsQ0FBQ0EsQ0FBQ0EsQ0FBQ0EsQ0FBQ0E7WUFDM0JBLElBQUlBLENBQUNBLFdBQVdBLEdBQUdBLENBQUNBLENBQUNBO1lBRXJCQSxFQUFFQSxDQUFDQSxDQUFDQSxJQUFJQSxDQUFDQSxpQ0FBaUNBLElBQUlBLElBQUlBLENBQUNBO2dCQUNsREEsSUFBSUEsQ0FBQ0EsaUNBQWlDQSxHQUFHQSxJQUFJQSxtQkFBbUJBLENBQUNBLG1CQUFtQkEsQ0FBQ0EsbUJBQW1CQSxFQUFFQSxJQUFJQSxDQUFDQSxVQUFVQSxFQUFFQSxJQUFJQSxFQUFFQSxJQUFJQSxDQUFDQSx3QkFBd0JBLENBQUNBLENBQUNBO1lBRWpLQSxJQUFJQSxDQUFDQSx3QkFBd0JBLENBQUNBLGFBQWFBLENBQUNBLElBQUlBLENBQUNBLGlDQUFpQ0EsQ0FBQ0EsQ0FBQ0E7UUFDckZBLENBQUNBO1FBRURBLGdCQUFLQSxDQUFDQSxZQUFZQSxZQUFDQSxJQUFJQSxDQUFDQSxDQUFDQTtJQUMxQkEsQ0FBQ0E7SUFDRkYsK0JBQUNBO0FBQURBLENBOUJBLEFBOEJDQSxFQTlCc0MsdUJBQXVCLEVBOEI3RDtBQUVELEFBQWtDLGlCQUF6Qix3QkFBd0IsQ0FBQyIsImZpbGUiOiJhbmltYXRvcnMvdHJhbnNpdGlvbnMvQ3Jvc3NmYWRlVHJhbnNpdGlvblN0YXRlLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2JiYXRlbWFuL1dlYnN0b3JtUHJvamVjdHMvYXdheWpzLXJlbmRlcmVyZ2wvIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEFuaW1hdG9yQmFzZVx0XHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1zdGFnZWdsL2xpYi9hbmltYXRvcnMvQW5pbWF0b3JCYXNlXCIpO1xuXG5pbXBvcnQgU2tlbGV0b25CaW5hcnlMRVJQTm9kZVx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvbm9kZXMvU2tlbGV0b25CaW5hcnlMRVJQTm9kZVwiKTtcbmltcG9ydCBTa2VsZXRvbkJpbmFyeUxFUlBTdGF0ZVx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1yZW5kZXJlcmdsL2xpYi9hbmltYXRvcnMvc3RhdGVzL1NrZWxldG9uQmluYXJ5TEVSUFN0YXRlXCIpO1xuaW1wb3J0IENyb3NzZmFkZVRyYW5zaXRpb25Ob2RlXHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXJlbmRlcmVyZ2wvbGliL2FuaW1hdG9ycy90cmFuc2l0aW9ucy9Dcm9zc2ZhZGVUcmFuc2l0aW9uTm9kZVwiKTtcbmltcG9ydCBBbmltYXRpb25TdGF0ZUV2ZW50XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvZXZlbnRzL0FuaW1hdGlvblN0YXRlRXZlbnRcIik7XG5cbi8qKlxuICpcbiAqL1xuY2xhc3MgQ3Jvc3NmYWRlVHJhbnNpdGlvblN0YXRlIGV4dGVuZHMgU2tlbGV0b25CaW5hcnlMRVJQU3RhdGVcbntcblx0cHJpdmF0ZSBfY3Jvc3NmYWRlVHJhbnNpdGlvbk5vZGU6Q3Jvc3NmYWRlVHJhbnNpdGlvbk5vZGU7XG5cdHByaXZhdGUgX2FuaW1hdGlvblN0YXRlVHJhbnNpdGlvbkNvbXBsZXRlOkFuaW1hdGlvblN0YXRlRXZlbnQ7XG5cblx0Y29uc3RydWN0b3IoYW5pbWF0b3I6QW5pbWF0b3JCYXNlLCBza2VsZXRvbkFuaW1hdGlvbk5vZGU6Q3Jvc3NmYWRlVHJhbnNpdGlvbk5vZGUpXG5cdHtcblx0XHRzdXBlcihhbmltYXRvciwgPFNrZWxldG9uQmluYXJ5TEVSUE5vZGU+IHNrZWxldG9uQW5pbWF0aW9uTm9kZSk7XG5cblx0XHR0aGlzLl9jcm9zc2ZhZGVUcmFuc2l0aW9uTm9kZSA9IHNrZWxldG9uQW5pbWF0aW9uTm9kZTtcblx0fVxuXG5cdC8qKlxuXHQgKiBAaW5oZXJpdERvY1xuXHQgKi9cblx0cHVibGljIF9wVXBkYXRlVGltZSh0aW1lOm51bWJlciAvKmludCovKVxuXHR7XG5cdFx0dGhpcy5ibGVuZFdlaWdodCA9IE1hdGguYWJzKHRpbWUgLSB0aGlzLl9jcm9zc2ZhZGVUcmFuc2l0aW9uTm9kZS5zdGFydEJsZW5kKS8oMTAwMCp0aGlzLl9jcm9zc2ZhZGVUcmFuc2l0aW9uTm9kZS5ibGVuZFNwZWVkKTtcblxuXHRcdGlmICh0aGlzLmJsZW5kV2VpZ2h0ID49IDEpIHtcblx0XHRcdHRoaXMuYmxlbmRXZWlnaHQgPSAxO1xuXG5cdFx0XHRpZiAodGhpcy5fYW5pbWF0aW9uU3RhdGVUcmFuc2l0aW9uQ29tcGxldGUgPT0gbnVsbClcblx0XHRcdFx0dGhpcy5fYW5pbWF0aW9uU3RhdGVUcmFuc2l0aW9uQ29tcGxldGUgPSBuZXcgQW5pbWF0aW9uU3RhdGVFdmVudChBbmltYXRpb25TdGF0ZUV2ZW50LlRSQU5TSVRJT05fQ09NUExFVEUsIHRoaXMuX3BBbmltYXRvciwgdGhpcywgdGhpcy5fY3Jvc3NmYWRlVHJhbnNpdGlvbk5vZGUpO1xuXG5cdFx0XHR0aGlzLl9jcm9zc2ZhZGVUcmFuc2l0aW9uTm9kZS5kaXNwYXRjaEV2ZW50KHRoaXMuX2FuaW1hdGlvblN0YXRlVHJhbnNpdGlvbkNvbXBsZXRlKTtcblx0XHR9XG5cblx0XHRzdXBlci5fcFVwZGF0ZVRpbWUodGltZSk7XG5cdH1cbn1cblxuZXhwb3J0ID0gQ3Jvc3NmYWRlVHJhbnNpdGlvblN0YXRlOyJdfQ==
\ No newline at end of file
diff --git a/lib/animators/transitions/CrossfadeTransitionState.ts b/lib/animators/transitions/CrossfadeTransitionState.ts
new file mode 100644
index 000000000..eff134e42
--- /dev/null
+++ b/lib/animators/transitions/CrossfadeTransitionState.ts
@@ -0,0 +1,43 @@
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+
+import SkeletonBinaryLERPNode = require("awayjs-renderergl/lib/animators/nodes/SkeletonBinaryLERPNode");
+import SkeletonBinaryLERPState = require("awayjs-renderergl/lib/animators/states/SkeletonBinaryLERPState");
+import CrossfadeTransitionNode = require("awayjs-renderergl/lib/animators/transitions/CrossfadeTransitionNode");
+import AnimationStateEvent = require("awayjs-renderergl/lib/events/AnimationStateEvent");
+
+/**
+ *
+ */
+class CrossfadeTransitionState extends SkeletonBinaryLERPState
+{
+ private _crossfadeTransitionNode:CrossfadeTransitionNode;
+ private _animationStateTransitionComplete:AnimationStateEvent;
+
+ constructor(animator:AnimatorBase, skeletonAnimationNode:CrossfadeTransitionNode)
+ {
+ super(animator, skeletonAnimationNode);
+
+ this._crossfadeTransitionNode = skeletonAnimationNode;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pUpdateTime(time:number /*int*/)
+ {
+ this.blendWeight = Math.abs(time - this._crossfadeTransitionNode.startBlend)/(1000*this._crossfadeTransitionNode.blendSpeed);
+
+ if (this.blendWeight >= 1) {
+ this.blendWeight = 1;
+
+ if (this._animationStateTransitionComplete == null)
+ this._animationStateTransitionComplete = new AnimationStateEvent(AnimationStateEvent.TRANSITION_COMPLETE, this._pAnimator, this, this._crossfadeTransitionNode);
+
+ this._crossfadeTransitionNode.dispatchEvent(this._animationStateTransitionComplete);
+ }
+
+ super._pUpdateTime(time);
+ }
+}
+
+export = CrossfadeTransitionState;
\ No newline at end of file
diff --git a/lib/animators/transitions/IAnimationTransition.js b/lib/animators/transitions/IAnimationTransition.js
new file mode 100755
index 000000000..9eb8adebf
--- /dev/null
+++ b/lib/animators/transitions/IAnimationTransition.js
@@ -0,0 +1,3 @@
+
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFuaW1hdG9ycy90cmFuc2l0aW9ucy9pYW5pbWF0aW9udHJhbnNpdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFZOEIiLCJmaWxlIjoiYW5pbWF0b3JzL3RyYW5zaXRpb25zL0lBbmltYXRpb25UcmFuc2l0aW9uLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2JiYXRlbWFuL1dlYnN0b3JtUHJvamVjdHMvYXdheWpzLXJlbmRlcmVyZ2wvIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEFuaW1hdGlvbk5vZGVCYXNlXHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtY29yZS9saWIvYW5pbWF0b3JzL25vZGVzL0FuaW1hdGlvbk5vZGVCYXNlXCIpO1xuXG5pbXBvcnQgQW5pbWF0b3JCYXNlXHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2FuaW1hdG9ycy9BbmltYXRvckJhc2VcIik7XG5cbi8qKlxuICpcbiAqL1xuaW50ZXJmYWNlIElBbmltYXRpb25UcmFuc2l0aW9uXG57XG5cdGdldEFuaW1hdGlvbk5vZGUoYW5pbWF0b3I6QW5pbWF0b3JCYXNlLCBzdGFydE5vZGU6QW5pbWF0aW9uTm9kZUJhc2UsIGVuZE5vZGU6QW5pbWF0aW9uTm9kZUJhc2UsIHN0YXJ0VGltZTpudW1iZXIgLyppbnQqLyk6QW5pbWF0aW9uTm9kZUJhc2Vcbn1cblxuZXhwb3J0ID0gSUFuaW1hdGlvblRyYW5zaXRpb247Il19
\ No newline at end of file
diff --git a/lib/animators/transitions/IAnimationTransition.ts b/lib/animators/transitions/IAnimationTransition.ts
new file mode 100644
index 000000000..da5e44e3d
--- /dev/null
+++ b/lib/animators/transitions/IAnimationTransition.ts
@@ -0,0 +1,13 @@
+import AnimationNodeBase = require("awayjs-core/lib/animators/nodes/AnimationNodeBase");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+
+/**
+ *
+ */
+interface IAnimationTransition
+{
+ getAnimationNode(animator:AnimatorBase, startNode:AnimationNodeBase, endNode:AnimationNodeBase, startTime:number /*int*/):AnimationNodeBase
+}
+
+export = IAnimationTransition;
\ No newline at end of file
diff --git a/lib/core/base/ParticleGeometry.js b/lib/core/base/ParticleGeometry.js
new file mode 100755
index 000000000..0c2438190
--- /dev/null
+++ b/lib/core/base/ParticleGeometry.js
@@ -0,0 +1,20 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Geometry = require("awayjs-core/lib/core/base/Geometry");
+/**
+ * @class away.base.ParticleGeometry
+ */
+var ParticleGeometry = (function (_super) {
+ __extends(ParticleGeometry, _super);
+ function ParticleGeometry() {
+ _super.apply(this, arguments);
+ }
+ return ParticleGeometry;
+})(Geometry);
+module.exports = ParticleGeometry;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvcmUvYmFzZS9wYXJ0aWNsZWdlb21ldHJ5LnRzIl0sIm5hbWVzIjpbIlBhcnRpY2xlR2VvbWV0cnkiLCJQYXJ0aWNsZUdlb21ldHJ5LmNvbnN0cnVjdG9yIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxJQUFPLFFBQVEsV0FBaUIsb0NBQW9DLENBQUMsQ0FBQztBQUl0RSxBQUdBOztHQURHO0lBQ0csZ0JBQWdCO0lBQVNBLFVBQXpCQSxnQkFBZ0JBLFVBQWlCQTtJQUF2Q0EsU0FBTUEsZ0JBQWdCQTtRQUFTQyw4QkFBUUE7SUFNdkNBLENBQUNBO0lBQURELHVCQUFDQTtBQUFEQSxDQU5BLEFBTUNBLEVBTjhCLFFBQVEsRUFNdEM7QUFFRCxBQUEwQixpQkFBakIsZ0JBQWdCLENBQUMiLCJmaWxlIjoiY29yZS9iYXNlL1BhcnRpY2xlR2VvbWV0cnkuanMiLCJzb3VyY2VSb290IjoiL1VzZXJzL3JvYmJhdGVtYW4vV2Vic3Rvcm1Qcm9qZWN0cy9hd2F5anMtcmVuZGVyZXJnbC8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgR2VvbWV0cnlcdFx0XHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1jb3JlL2xpYi9jb3JlL2Jhc2UvR2VvbWV0cnlcIik7XG5cbmltcG9ydCBQYXJ0aWNsZURhdGFcdFx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtcmVuZGVyZXJnbC9saWIvYW5pbWF0b3JzL2RhdGEvUGFydGljbGVEYXRhXCIpO1xuXG4vKipcbiAqIEBjbGFzcyBhd2F5LmJhc2UuUGFydGljbGVHZW9tZXRyeVxuICovXG5jbGFzcyBQYXJ0aWNsZUdlb21ldHJ5IGV4dGVuZHMgR2VvbWV0cnlcbntcblx0cHVibGljIHBhcnRpY2xlczpBcnJheTxQYXJ0aWNsZURhdGE+O1xuXG5cdHB1YmxpYyBudW1QYXJ0aWNsZXM6bnVtYmVyIC8qdWludCovO1xuXG59XG5cbmV4cG9ydCA9IFBhcnRpY2xlR2VvbWV0cnk7Il19
\ No newline at end of file
diff --git a/lib/core/base/ParticleGeometry.ts b/lib/core/base/ParticleGeometry.ts
new file mode 100644
index 000000000..ef3fe100b
--- /dev/null
+++ b/lib/core/base/ParticleGeometry.ts
@@ -0,0 +1,16 @@
+import Geometry = require("awayjs-core/lib/core/base/Geometry");
+
+import ParticleData = require("awayjs-renderergl/lib/animators/data/ParticleData");
+
+/**
+ * @class away.base.ParticleGeometry
+ */
+class ParticleGeometry extends Geometry
+{
+ public particles:Array;
+
+ public numParticles:number /*uint*/;
+
+}
+
+export = ParticleGeometry;
\ No newline at end of file
diff --git a/lib/core/pick/JSPickingCollider.js b/lib/core/pick/JSPickingCollider.js
new file mode 100755
index 000000000..cfce29082
--- /dev/null
+++ b/lib/core/pick/JSPickingCollider.js
@@ -0,0 +1,137 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var TriangleSubGeometry = require("awayjs-core/lib/core/base/TriangleSubGeometry");
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var PickingColliderBase = require("awayjs-renderergl/lib/core/pick/PickingColliderBase");
+/**
+ * Pure JS picking collider for display objects. Used with the RaycastPicker
picking object.
+ *
+ * @see away.base.DisplayObject#pickingCollider
+ * @see away.pick.RaycastPicker
+ *
+ * @class away.pick.JSPickingCollider
+ */
+var JSPickingCollider = (function (_super) {
+ __extends(JSPickingCollider, _super);
+ /**
+ * Creates a new JSPickingCollider
object.
+ *
+ * @param findClosestCollision Determines whether the picking collider searches for the closest collision along the ray. Defaults to false.
+ */
+ function JSPickingCollider(findClosestCollision) {
+ if (findClosestCollision === void 0) { findClosestCollision = false; }
+ _super.call(this);
+ this._findClosestCollision = findClosestCollision;
+ }
+ /**
+ * @inheritDoc
+ */
+ JSPickingCollider.prototype._pTestRenderableCollision = function (renderable, pickingCollisionVO, shortestCollisionDistance) {
+ var t;
+ var i0, i1, i2;
+ var rx, ry, rz;
+ var nx, ny, nz;
+ var cx, cy, cz;
+ var coeff, u, v, w;
+ var p0x, p0y, p0z;
+ var p1x, p1y, p1z;
+ var p2x, p2y, p2z;
+ var s0x, s0y, s0z;
+ var s1x, s1y, s1z;
+ var nl, nDotV, D, disToPlane;
+ var Q1Q2, Q1Q1, Q2Q2, RQ1, RQ2;
+ var indexData = renderable.getIndexData().data;
+ var collisionTriangleIndex = -1;
+ var bothSides = renderable.materialOwner.material.bothSides;
+ var positionData = renderable.getVertexData(TriangleSubGeometry.POSITION_DATA).data;
+ var positionStride = renderable.getVertexData(TriangleSubGeometry.POSITION_DATA).dataPerVertex;
+ var positionOffset = renderable.getVertexOffset(TriangleSubGeometry.POSITION_DATA);
+ var uvData = renderable.getVertexData(TriangleSubGeometry.UV_DATA).data;
+ var uvStride = renderable.getVertexData(TriangleSubGeometry.UV_DATA).dataPerVertex;
+ var uvOffset = renderable.getVertexOffset(TriangleSubGeometry.UV_DATA);
+ var numIndices = indexData.length;
+ for (var index = 0; index < numIndices; index += 3) {
+ // evaluate triangle indices
+ i0 = positionOffset + indexData[index] * positionStride;
+ i1 = positionOffset + indexData[(index + 1)] * positionStride;
+ i2 = positionOffset + indexData[(index + 2)] * positionStride;
+ // evaluate triangle positions
+ p0x = positionData[i0];
+ p0y = positionData[(i0 + 1)];
+ p0z = positionData[(i0 + 2)];
+ p1x = positionData[i1];
+ p1y = positionData[(i1 + 1)];
+ p1z = positionData[(i1 + 2)];
+ p2x = positionData[i2];
+ p2y = positionData[(i2 + 1)];
+ p2z = positionData[(i2 + 2)];
+ // evaluate sides and triangle normal
+ s0x = p1x - p0x; // s0 = p1 - p0
+ s0y = p1y - p0y;
+ s0z = p1z - p0z;
+ s1x = p2x - p0x; // s1 = p2 - p0
+ s1y = p2y - p0y;
+ s1z = p2z - p0z;
+ nx = s0y * s1z - s0z * s1y; // n = s0 x s1
+ ny = s0z * s1x - s0x * s1z;
+ nz = s0x * s1y - s0y * s1x;
+ nl = 1 / Math.sqrt(nx * nx + ny * ny + nz * nz); // normalize n
+ nx *= nl;
+ ny *= nl;
+ nz *= nl;
+ // -- plane intersection test --
+ nDotV = nx * this.rayDirection.x + ny * +this.rayDirection.y + nz * this.rayDirection.z; // rayDirection . normal
+ if ((!bothSides && nDotV < 0.0) || (bothSides && nDotV != 0.0)) {
+ // find collision t
+ D = -(nx * p0x + ny * p0y + nz * p0z);
+ disToPlane = -(nx * this.rayPosition.x + ny * this.rayPosition.y + nz * this.rayPosition.z + D);
+ t = disToPlane / nDotV;
+ // find collision point
+ cx = this.rayPosition.x + t * this.rayDirection.x;
+ cy = this.rayPosition.y + t * this.rayDirection.y;
+ cz = this.rayPosition.z + t * this.rayDirection.z;
+ // collision point inside triangle? ( using barycentric coordinates )
+ Q1Q2 = s0x * s1x + s0y * s1y + s0z * s1z;
+ Q1Q1 = s0x * s0x + s0y * s0y + s0z * s0z;
+ Q2Q2 = s1x * s1x + s1y * s1y + s1z * s1z;
+ rx = cx - p0x;
+ ry = cy - p0y;
+ rz = cz - p0z;
+ RQ1 = rx * s0x + ry * s0y + rz * s0z;
+ RQ2 = rx * s1x + ry * s1y + rz * s1z;
+ coeff = 1 / (Q1Q1 * Q2Q2 - Q1Q2 * Q1Q2);
+ v = coeff * (Q2Q2 * RQ1 - Q1Q2 * RQ2);
+ w = coeff * (-Q1Q2 * RQ1 + Q1Q1 * RQ2);
+ if (v < 0)
+ continue;
+ if (w < 0)
+ continue;
+ u = 1 - v - w;
+ if (!(u < 0) && t > 0 && t < shortestCollisionDistance) {
+ shortestCollisionDistance = t;
+ collisionTriangleIndex = index / 3;
+ pickingCollisionVO.rayEntryDistance = t;
+ pickingCollisionVO.localPosition = new Vector3D(cx, cy, cz);
+ pickingCollisionVO.localNormal = new Vector3D(nx, ny, nz);
+ pickingCollisionVO.uv = this._pGetCollisionUV(indexData, uvData, index, v, w, u, uvOffset, uvStride);
+ pickingCollisionVO.index = index;
+ // pickingCollisionVO.subGeometryIndex = this.pGetMeshSubMeshIndex(renderable);
+ // if not looking for best hit, first found will do...
+ if (!this._findClosestCollision)
+ return true;
+ }
+ }
+ }
+ if (collisionTriangleIndex >= 0)
+ return true;
+ return false;
+ };
+ return JSPickingCollider;
+})(PickingColliderBase);
+module.exports = JSPickingCollider;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["core/pick/jspickingcollider.ts"],"names":["JSPickingCollider","JSPickingCollider.constructor","JSPickingCollider._pTestRenderableCollision"],"mappings":"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","file":"core/pick/JSPickingCollider.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import TriangleSubGeometry\t\t\t\t= require(\"awayjs-core/lib/core/base/TriangleSubGeometry\");\nimport Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\nimport PickingCollisionVO\t\t\t\t= require(\"awayjs-core/lib/core/pick/PickingCollisionVO\");\nimport IPickingCollider\t\t\t\t\t= require(\"awayjs-core/lib/core/pick/IPickingCollider\");\nimport MaterialBase\t\t\t\t\t\t= require(\"awayjs-core/lib/materials/MaterialBase\");\n\nimport RenderableBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/RenderableBase\");\n\nimport PickingColliderBase\t\t\t\t= require(\"awayjs-renderergl/lib/core/pick/PickingColliderBase\");\n\n/**\n * Pure JS picking collider for display objects. Used with the <code>RaycastPicker</code> picking object.\n *\n * @see away.base.DisplayObject#pickingCollider\n * @see away.pick.RaycastPicker\n *\n * @class away.pick.JSPickingCollider\n */\nclass JSPickingCollider extends PickingColliderBase implements IPickingCollider\n{\n\tprivate _findClosestCollision:boolean;\n\n\t/**\n\t * Creates a new <code>JSPickingCollider</code> object.\n\t *\n\t * @param findClosestCollision Determines whether the picking collider searches for the closest collision along the ray. Defaults to false.\n\t */\n\tconstructor(findClosestCollision:boolean = false)\n\t{\n\t\tsuper();\n\n\t\tthis._findClosestCollision = findClosestCollision;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _pTestRenderableCollision(renderable:RenderableBase, pickingCollisionVO:PickingCollisionVO, shortestCollisionDistance:number):boolean\n\t{\n\t\tvar t:number;\n\t\tvar i0:number, i1:number, i2:number;\n\t\tvar rx:number, ry:number, rz:number;\n\t\tvar nx:number, ny:number, nz:number;\n\t\tvar cx:number, cy:number, cz:number;\n\t\tvar coeff:number, u:number, v:number, w:number;\n\t\tvar p0x:number, p0y:number, p0z:number;\n\t\tvar p1x:number, p1y:number, p1z:number;\n\t\tvar p2x:number, p2y:number, p2z:number;\n\t\tvar s0x:number, s0y:number, s0z:number;\n\t\tvar s1x:number, s1y:number, s1z:number;\n\t\tvar nl:number, nDotV:number, D:number, disToPlane:number;\n\t\tvar Q1Q2:number, Q1Q1:number, Q2Q2:number, RQ1:number, RQ2:number;\n\t\tvar indexData:Array<number> = renderable.getIndexData().data;\n\t\tvar collisionTriangleIndex:number = -1;\n\t\tvar bothSides:boolean = (<MaterialBase> renderable.materialOwner.material).bothSides;\n\n\t\tvar positionData:Array<number> = renderable.getVertexData(TriangleSubGeometry.POSITION_DATA).data;\n\t\tvar positionStride:number = renderable.getVertexData(TriangleSubGeometry.POSITION_DATA).dataPerVertex;\n\t\tvar positionOffset:number = renderable.getVertexOffset(TriangleSubGeometry.POSITION_DATA);\n\t\tvar uvData:Array<number> = renderable.getVertexData(TriangleSubGeometry.UV_DATA).data;\n\t\tvar uvStride:number = renderable.getVertexData(TriangleSubGeometry.UV_DATA).dataPerVertex;\n\t\tvar uvOffset:number = renderable.getVertexOffset(TriangleSubGeometry.UV_DATA);\n\t\tvar numIndices:number = indexData.length;\n\n\t\tfor (var index:number = 0; index < numIndices; index += 3) { // sweep all triangles\n\t\t\t// evaluate triangle indices\n\t\t\ti0 = positionOffset + indexData[ index ]*positionStride;\n\t\t\ti1 = positionOffset + indexData[ (index + 1) ]*positionStride;\n\t\t\ti2 = positionOffset + indexData[ (index + 2) ]*positionStride;\n\n\t\t\t// evaluate triangle positions\n\t\t\tp0x = positionData[ i0 ];\n\t\t\tp0y = positionData[ (i0 + 1) ];\n\t\t\tp0z = positionData[ (i0 + 2) ];\n\t\t\tp1x = positionData[ i1 ];\n\t\t\tp1y = positionData[ (i1 + 1) ];\n\t\t\tp1z = positionData[ (i1 + 2) ];\n\t\t\tp2x = positionData[ i2 ];\n\t\t\tp2y = positionData[ (i2 + 1) ];\n\t\t\tp2z = positionData[ (i2 + 2) ];\n\n\t\t\t// evaluate sides and triangle normal\n\t\t\ts0x = p1x - p0x; // s0 = p1 - p0\n\t\t\ts0y = p1y - p0y;\n\t\t\ts0z = p1z - p0z;\n\t\t\ts1x = p2x - p0x; // s1 = p2 - p0\n\t\t\ts1y = p2y - p0y;\n\t\t\ts1z = p2z - p0z;\n\t\t\tnx = s0y*s1z - s0z*s1y; // n = s0 x s1\n\t\t\tny = s0z*s1x - s0x*s1z;\n\t\t\tnz = s0x*s1y - s0y*s1x;\n\t\t\tnl = 1/Math.sqrt(nx*nx + ny*ny + nz*nz); // normalize n\n\t\t\tnx *= nl;\n\t\t\tny *= nl;\n\t\t\tnz *= nl;\n\n\t\t\t// -- plane intersection test --\n\t\t\tnDotV = nx*this.rayDirection.x + ny* +this.rayDirection.y + nz*this.rayDirection.z; // rayDirection . normal\n\t\t\tif (( !bothSides && nDotV < 0.0 ) || ( bothSides && nDotV != 0.0 )) { // an intersection must exist\n\t\t\t\t// find collision t\n\t\t\t\tD = -( nx*p0x + ny*p0y + nz*p0z );\n\t\t\t\tdisToPlane = -( nx*this.rayPosition.x + ny*this.rayPosition.y + nz*this.rayPosition.z + D );\n\t\t\t\tt = disToPlane/nDotV;\n\t\t\t\t// find collision point\n\t\t\t\tcx = this.rayPosition.x + t*this.rayDirection.x;\n\t\t\t\tcy = this.rayPosition.y + t*this.rayDirection.y;\n\t\t\t\tcz = this.rayPosition.z + t*this.rayDirection.z;\n\t\t\t\t// collision point inside triangle? ( using barycentric coordinates )\n\t\t\t\tQ1Q2 = s0x*s1x + s0y*s1y + s0z*s1z;\n\t\t\t\tQ1Q1 = s0x*s0x + s0y*s0y + s0z*s0z;\n\t\t\t\tQ2Q2 = s1x*s1x + s1y*s1y + s1z*s1z;\n\t\t\t\trx = cx - p0x;\n\t\t\t\try = cy - p0y;\n\t\t\t\trz = cz - p0z;\n\t\t\t\tRQ1 = rx*s0x + ry*s0y + rz*s0z;\n\t\t\t\tRQ2 = rx*s1x + ry*s1y + rz*s1z;\n\t\t\t\tcoeff = 1/( Q1Q1*Q2Q2 - Q1Q2*Q1Q2 );\n\t\t\t\tv = coeff*( Q2Q2*RQ1 - Q1Q2*RQ2 );\n\t\t\t\tw = coeff*( -Q1Q2*RQ1 + Q1Q1*RQ2 );\n\t\t\t\tif (v < 0)\n\t\t\t\t\tcontinue;\n\t\t\t\tif (w < 0)\n\t\t\t\t\tcontinue;\n\t\t\t\tu = 1 - v - w;\n\t\t\t\tif (!( u < 0 ) && t > 0 && t < shortestCollisionDistance) { // all tests passed\n\t\t\t\t\tshortestCollisionDistance = t;\n\t\t\t\t\tcollisionTriangleIndex = index/3;\n\t\t\t\t\tpickingCollisionVO.rayEntryDistance = t;\n\t\t\t\t\tpickingCollisionVO.localPosition = new Vector3D(cx, cy, cz);\n\t\t\t\t\tpickingCollisionVO.localNormal = new Vector3D(nx, ny, nz);\n\t\t\t\t\tpickingCollisionVO.uv = this._pGetCollisionUV(indexData, uvData, index, v, w, u, uvOffset, uvStride);\n\t\t\t\t\tpickingCollisionVO.index = index;\n//\t\t\t\t\t\tpickingCollisionVO.subGeometryIndex = this.pGetMeshSubMeshIndex(renderable);\n\n\t\t\t\t\t// if not looking for best hit, first found will do...\n\t\t\t\t\tif (!this._findClosestCollision)\n\t\t\t\t\t\treturn true;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\n\t\tif (collisionTriangleIndex >= 0)\n\t\t\treturn true;\n\n\t\treturn false;\n\t}\n}\n\nexport = JSPickingCollider;"]}
\ No newline at end of file
diff --git a/lib/core/pick/JSPickingCollider.ts b/lib/core/pick/JSPickingCollider.ts
new file mode 100644
index 000000000..533fb78d2
--- /dev/null
+++ b/lib/core/pick/JSPickingCollider.ts
@@ -0,0 +1,150 @@
+import TriangleSubGeometry = require("awayjs-core/lib/core/base/TriangleSubGeometry");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import PickingCollisionVO = require("awayjs-core/lib/core/pick/PickingCollisionVO");
+import IPickingCollider = require("awayjs-core/lib/core/pick/IPickingCollider");
+import MaterialBase = require("awayjs-core/lib/materials/MaterialBase");
+
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+
+import PickingColliderBase = require("awayjs-renderergl/lib/core/pick/PickingColliderBase");
+
+/**
+ * Pure JS picking collider for display objects. Used with the RaycastPicker
picking object.
+ *
+ * @see away.base.DisplayObject#pickingCollider
+ * @see away.pick.RaycastPicker
+ *
+ * @class away.pick.JSPickingCollider
+ */
+class JSPickingCollider extends PickingColliderBase implements IPickingCollider
+{
+ private _findClosestCollision:boolean;
+
+ /**
+ * Creates a new JSPickingCollider
object.
+ *
+ * @param findClosestCollision Determines whether the picking collider searches for the closest collision along the ray. Defaults to false.
+ */
+ constructor(findClosestCollision:boolean = false)
+ {
+ super();
+
+ this._findClosestCollision = findClosestCollision;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pTestRenderableCollision(renderable:RenderableBase, pickingCollisionVO:PickingCollisionVO, shortestCollisionDistance:number):boolean
+ {
+ var t:number;
+ var i0:number, i1:number, i2:number;
+ var rx:number, ry:number, rz:number;
+ var nx:number, ny:number, nz:number;
+ var cx:number, cy:number, cz:number;
+ var coeff:number, u:number, v:number, w:number;
+ var p0x:number, p0y:number, p0z:number;
+ var p1x:number, p1y:number, p1z:number;
+ var p2x:number, p2y:number, p2z:number;
+ var s0x:number, s0y:number, s0z:number;
+ var s1x:number, s1y:number, s1z:number;
+ var nl:number, nDotV:number, D:number, disToPlane:number;
+ var Q1Q2:number, Q1Q1:number, Q2Q2:number, RQ1:number, RQ2:number;
+ var indexData:Array = renderable.getIndexData().data;
+ var collisionTriangleIndex:number = -1;
+ var bothSides:boolean = ( renderable.materialOwner.material).bothSides;
+
+ var positionData:Array = renderable.getVertexData(TriangleSubGeometry.POSITION_DATA).data;
+ var positionStride:number = renderable.getVertexData(TriangleSubGeometry.POSITION_DATA).dataPerVertex;
+ var positionOffset:number = renderable.getVertexOffset(TriangleSubGeometry.POSITION_DATA);
+ var uvData:Array = renderable.getVertexData(TriangleSubGeometry.UV_DATA).data;
+ var uvStride:number = renderable.getVertexData(TriangleSubGeometry.UV_DATA).dataPerVertex;
+ var uvOffset:number = renderable.getVertexOffset(TriangleSubGeometry.UV_DATA);
+ var numIndices:number = indexData.length;
+
+ for (var index:number = 0; index < numIndices; index += 3) { // sweep all triangles
+ // evaluate triangle indices
+ i0 = positionOffset + indexData[ index ]*positionStride;
+ i1 = positionOffset + indexData[ (index + 1) ]*positionStride;
+ i2 = positionOffset + indexData[ (index + 2) ]*positionStride;
+
+ // evaluate triangle positions
+ p0x = positionData[ i0 ];
+ p0y = positionData[ (i0 + 1) ];
+ p0z = positionData[ (i0 + 2) ];
+ p1x = positionData[ i1 ];
+ p1y = positionData[ (i1 + 1) ];
+ p1z = positionData[ (i1 + 2) ];
+ p2x = positionData[ i2 ];
+ p2y = positionData[ (i2 + 1) ];
+ p2z = positionData[ (i2 + 2) ];
+
+ // evaluate sides and triangle normal
+ s0x = p1x - p0x; // s0 = p1 - p0
+ s0y = p1y - p0y;
+ s0z = p1z - p0z;
+ s1x = p2x - p0x; // s1 = p2 - p0
+ s1y = p2y - p0y;
+ s1z = p2z - p0z;
+ nx = s0y*s1z - s0z*s1y; // n = s0 x s1
+ ny = s0z*s1x - s0x*s1z;
+ nz = s0x*s1y - s0y*s1x;
+ nl = 1/Math.sqrt(nx*nx + ny*ny + nz*nz); // normalize n
+ nx *= nl;
+ ny *= nl;
+ nz *= nl;
+
+ // -- plane intersection test --
+ nDotV = nx*this.rayDirection.x + ny* +this.rayDirection.y + nz*this.rayDirection.z; // rayDirection . normal
+ if (( !bothSides && nDotV < 0.0 ) || ( bothSides && nDotV != 0.0 )) { // an intersection must exist
+ // find collision t
+ D = -( nx*p0x + ny*p0y + nz*p0z );
+ disToPlane = -( nx*this.rayPosition.x + ny*this.rayPosition.y + nz*this.rayPosition.z + D );
+ t = disToPlane/nDotV;
+ // find collision point
+ cx = this.rayPosition.x + t*this.rayDirection.x;
+ cy = this.rayPosition.y + t*this.rayDirection.y;
+ cz = this.rayPosition.z + t*this.rayDirection.z;
+ // collision point inside triangle? ( using barycentric coordinates )
+ Q1Q2 = s0x*s1x + s0y*s1y + s0z*s1z;
+ Q1Q1 = s0x*s0x + s0y*s0y + s0z*s0z;
+ Q2Q2 = s1x*s1x + s1y*s1y + s1z*s1z;
+ rx = cx - p0x;
+ ry = cy - p0y;
+ rz = cz - p0z;
+ RQ1 = rx*s0x + ry*s0y + rz*s0z;
+ RQ2 = rx*s1x + ry*s1y + rz*s1z;
+ coeff = 1/( Q1Q1*Q2Q2 - Q1Q2*Q1Q2 );
+ v = coeff*( Q2Q2*RQ1 - Q1Q2*RQ2 );
+ w = coeff*( -Q1Q2*RQ1 + Q1Q1*RQ2 );
+ if (v < 0)
+ continue;
+ if (w < 0)
+ continue;
+ u = 1 - v - w;
+ if (!( u < 0 ) && t > 0 && t < shortestCollisionDistance) { // all tests passed
+ shortestCollisionDistance = t;
+ collisionTriangleIndex = index/3;
+ pickingCollisionVO.rayEntryDistance = t;
+ pickingCollisionVO.localPosition = new Vector3D(cx, cy, cz);
+ pickingCollisionVO.localNormal = new Vector3D(nx, ny, nz);
+ pickingCollisionVO.uv = this._pGetCollisionUV(indexData, uvData, index, v, w, u, uvOffset, uvStride);
+ pickingCollisionVO.index = index;
+// pickingCollisionVO.subGeometryIndex = this.pGetMeshSubMeshIndex(renderable);
+
+ // if not looking for best hit, first found will do...
+ if (!this._findClosestCollision)
+ return true;
+ }
+ }
+ }
+
+
+ if (collisionTriangleIndex >= 0)
+ return true;
+
+ return false;
+ }
+}
+
+export = JSPickingCollider;
\ No newline at end of file
diff --git a/lib/core/pick/PickingColliderBase.js b/lib/core/pick/PickingColliderBase.js
new file mode 100755
index 000000000..352dd9f8a
--- /dev/null
+++ b/lib/core/pick/PickingColliderBase.js
@@ -0,0 +1,102 @@
+var RenderablePool = require("awayjs-core/lib/core/pool/RenderablePool");
+var Point = require("awayjs-core/lib/core/geom/Point");
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var AbstractMethodError = require("awayjs-core/lib/errors/AbstractMethodError");
+var BillboardRenderable = require("awayjs-stagegl/lib/core/pool/BillboardRenderable");
+var TriangleSubMeshRenderable = require("awayjs-stagegl/lib/core/pool/TriangleSubMeshRenderable");
+/**
+ * An abstract base class for all picking collider classes. It should not be instantiated directly.
+ *
+ * @class away.pick.PickingColliderBase
+ */
+var PickingColliderBase = (function () {
+ function PickingColliderBase() {
+ this._billboardRenderablePool = RenderablePool.getPool(BillboardRenderable);
+ this._subMeshRenderablePool = RenderablePool.getPool(TriangleSubMeshRenderable);
+ }
+ PickingColliderBase.prototype._pPetCollisionNormal = function (indexData /*uint*/, vertexData, triangleIndex) {
+ var normal = new Vector3D();
+ var i0 = indexData[triangleIndex] * 3;
+ var i1 = indexData[triangleIndex + 1] * 3;
+ var i2 = indexData[triangleIndex + 2] * 3;
+ var p0 = new Vector3D(vertexData[i0], vertexData[i0 + 1], vertexData[i0 + 2]);
+ var p1 = new Vector3D(vertexData[i1], vertexData[i1 + 1], vertexData[i1 + 2]);
+ var p2 = new Vector3D(vertexData[i2], vertexData[i2 + 1], vertexData[i2 + 2]);
+ var side0 = p1.subtract(p0);
+ var side1 = p2.subtract(p0);
+ normal = side0.crossProduct(side1);
+ normal.normalize();
+ return normal;
+ };
+ PickingColliderBase.prototype._pGetCollisionUV = function (indexData /*uint*/, uvData, triangleIndex, v, w, u, uvOffset, uvStride) {
+ var uv = new Point();
+ var uIndex = indexData[triangleIndex] * uvStride + uvOffset;
+ var uv0 = new Vector3D(uvData[uIndex], uvData[uIndex + 1]);
+ uIndex = indexData[triangleIndex + 1] * uvStride + uvOffset;
+ var uv1 = new Vector3D(uvData[uIndex], uvData[uIndex + 1]);
+ uIndex = indexData[triangleIndex + 2] * uvStride + uvOffset;
+ var uv2 = new Vector3D(uvData[uIndex], uvData[uIndex + 1]);
+ uv.x = u * uv0.x + v * uv1.x + w * uv2.x;
+ uv.y = u * uv0.y + v * uv1.y + w * uv2.y;
+ return uv;
+ };
+ /**
+ * @inheritDoc
+ */
+ PickingColliderBase.prototype._pTestRenderableCollision = function (renderable, pickingCollisionVO, shortestCollisionDistance) {
+ throw new AbstractMethodError();
+ };
+ /**
+ * @inheritDoc
+ */
+ PickingColliderBase.prototype.setLocalRay = function (localPosition, localDirection) {
+ this.rayPosition = localPosition;
+ this.rayDirection = localDirection;
+ };
+ /**
+ * Tests a Billboard
object for a collision with the picking ray.
+ *
+ * @param billboard The billboard instance to be tested.
+ * @param pickingCollisionVO The collision object used to store the collision results
+ * @param shortestCollisionDistance The current value of the shortest distance to a detected collision along the ray.
+ * @param findClosest
+ */
+ PickingColliderBase.prototype.testBillboardCollision = function (billboard, pickingCollisionVO, shortestCollisionDistance) {
+ this.setLocalRay(pickingCollisionVO.localRayPosition, pickingCollisionVO.localRayDirection);
+ pickingCollisionVO.materialOwner = null;
+ if (this._pTestRenderableCollision(this._billboardRenderablePool.getItem(billboard), pickingCollisionVO, shortestCollisionDistance)) {
+ shortestCollisionDistance = pickingCollisionVO.rayEntryDistance;
+ pickingCollisionVO.materialOwner = billboard;
+ return true;
+ }
+ return false;
+ };
+ /**
+ * Tests a Mesh
object for a collision with the picking ray.
+ *
+ * @param mesh The mesh instance to be tested.
+ * @param pickingCollisionVO The collision object used to store the collision results
+ * @param shortestCollisionDistance The current value of the shortest distance to a detected collision along the ray.
+ * @param findClosest
+ */
+ PickingColliderBase.prototype.testMeshCollision = function (mesh, pickingCollisionVO, shortestCollisionDistance, findClosest) {
+ this.setLocalRay(pickingCollisionVO.localRayPosition, pickingCollisionVO.localRayDirection);
+ pickingCollisionVO.materialOwner = null;
+ var subMesh;
+ var len = mesh.subMeshes.length;
+ for (var i = 0; i < len; ++i) {
+ subMesh = mesh.subMeshes[i];
+ if (this._pTestRenderableCollision(this._subMeshRenderablePool.getItem(subMesh), pickingCollisionVO, shortestCollisionDistance)) {
+ shortestCollisionDistance = pickingCollisionVO.rayEntryDistance;
+ pickingCollisionVO.materialOwner = subMesh;
+ if (!findClosest)
+ return true;
+ }
+ }
+ return pickingCollisionVO.materialOwner != null;
+ };
+ return PickingColliderBase;
+})();
+module.exports = PickingColliderBase;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["core/pick/pickingcolliderbase.ts"],"names":["PickingColliderBase","PickingColliderBase.constructor","PickingColliderBase._pPetCollisionNormal","PickingColliderBase._pGetCollisionUV","PickingColliderBase._pTestRenderableCollision","PickingColliderBase.setLocalRay","PickingColliderBase.testBillboardCollision","PickingColliderBase.testMeshCollision"],"mappings":"AAEA,IAAO,cAAc,WAAe,0CAA0C,CAAC,CAAC;AAChF,IAAO,KAAK,WAAiB,iCAAiC,CAAC,CAAC;AAChE,IAAO,QAAQ,WAAiB,oCAAoC,CAAC,CAAC;AAGtE,IAAO,mBAAmB,WAAc,4CAA4C,CAAC,CAAC;AAEtF,IAAO,mBAAmB,WAAc,kDAAkD,CAAC,CAAC;AAE5F,IAAO,yBAAyB,WAAY,wDAAwD,CAAC,CAAC;AAEtG,AAKA;;;;GADG;IACG,mBAAmB;IAQxBA,SARKA,mBAAmBA;QAUvBC,IAAIA,CAACA,wBAAwBA,GAAGA,cAAcA,CAACA,OAAOA,CAACA,mBAAmBA,CAACA,CAACA;QAC5EA,IAAIA,CAACA,sBAAsBA,GAAGA,cAAcA,CAACA,OAAOA,CAACA,yBAAyBA,CAACA,CAACA;IACjFA,CAACA;IAEMD,kDAAoBA,GAA3BA,UAA4BA,SAASA,CAAeA,QAADA,AAASA,EAAEA,UAAwBA,EAAEA,aAAoBA;QAE3GE,IAAIA,MAAMA,GAAYA,IAAIA,QAAQA,EAAEA,CAACA;QACrCA,IAAIA,EAAEA,GAAUA,SAASA,CAAEA,aAAaA,CAAEA,GAACA,CAACA,CAACA;QAC7CA,IAAIA,EAAEA,GAAUA,SAASA,CAAEA,aAAaA,GAAGA,CAACA,CAAEA,GAACA,CAACA,CAACA;QACjDA,IAAIA,EAAEA,GAAUA,SAASA,CAAEA,aAAaA,GAAGA,CAACA,CAAEA,GAACA,CAACA,CAACA;QACjDA,IAAIA,EAAEA,GAAYA,IAAIA,QAAQA,CAACA,UAAUA,CAAEA,EAAEA,CAAEA,EAAEA,UAAUA,CAAEA,EAAEA,GAAGA,CAACA,CAAEA,EAAEA,UAAUA,CAAEA,EAAEA,GAAGA,CAACA,CAAEA,CAACA,CAACA;QAC7FA,IAAIA,EAAEA,GAAYA,IAAIA,QAAQA,CAACA,UAAUA,CAAEA,EAAEA,CAAEA,EAAEA,UAAUA,CAAEA,EAAEA,GAAGA,CAACA,CAAEA,EAAEA,UAAUA,CAAEA,EAAEA,GAAGA,CAACA,CAAEA,CAACA,CAACA;QAC7FA,IAAIA,EAAEA,GAAYA,IAAIA,QAAQA,CAACA,UAAUA,CAAEA,EAAEA,CAAEA,EAAEA,UAAUA,CAAEA,EAAEA,GAAGA,CAACA,CAAEA,EAAEA,UAAUA,CAAEA,EAAEA,GAAGA,CAACA,CAAEA,CAACA,CAACA;QAC7FA,IAAIA,KAAKA,GAAYA,EAAEA,CAACA,QAAQA,CAACA,EAAEA,CAACA,CAACA;QACrCA,IAAIA,KAAKA,GAAYA,EAAEA,CAACA,QAAQA,CAACA,EAAEA,CAACA,CAACA;QACrCA,MAAMA,GAAGA,KAAKA,CAACA,YAAYA,CAACA,KAAKA,CAACA,CAACA;QACnCA,MAAMA,CAACA,SAASA,EAAEA,CAACA;QACnBA,MAAMA,CAACA,MAAMA,CAACA;IACfA,CAACA;IAEMF,8CAAgBA,GAAvBA,UAAwBA,SAASA,CAAeA,QAADA,AAASA,EAAEA,MAAoBA,EAAEA,aAAoBA,EAAEA,CAAQA,EAAEA,CAAQA,EAAEA,CAAQA,EAAEA,QAAeA,EAAEA,QAAeA;QAEnKG,IAAIA,EAAEA,GAASA,IAAIA,KAAKA,EAAEA,CAACA;QAC3BA,IAAIA,MAAMA,GAAUA,SAASA,CAAEA,aAAaA,CAAEA,GAACA,QAAQA,GAAGA,QAAQA,CAACA;QACnEA,IAAIA,GAAGA,GAAYA,IAAIA,QAAQA,CAACA,MAAMA,CAAEA,MAAMA,CAAEA,EAAEA,MAAMA,CAAEA,MAAMA,GAAGA,CAACA,CAAEA,CAACA,CAACA;QACxEA,MAAMA,GAAGA,SAASA,CAAEA,aAAaA,GAAGA,CAACA,CAAEA,GAACA,QAAQA,GAAGA,QAAQA,CAACA;QAC5DA,IAAIA,GAAGA,GAAYA,IAAIA,QAAQA,CAACA,MAAMA,CAAEA,MAAMA,CAAEA,EAAEA,MAAMA,CAAEA,MAAMA,GAAGA,CAACA,CAAEA,CAACA,CAACA;QACxEA,MAAMA,GAAGA,SAASA,CAAEA,aAAaA,GAAGA,CAACA,CAAEA,GAACA,QAAQA,GAAGA,QAAQA,CAACA;QAC5DA,IAAIA,GAAGA,GAAYA,IAAIA,QAAQA,CAACA,MAAMA,CAAEA,MAAMA,CAAEA,EAAEA,MAAMA,CAAEA,MAAMA,GAAGA,CAACA,CAAEA,CAACA,CAACA;QACxEA,EAAEA,CAACA,CAACA,GAAGA,CAACA,GAACA,GAAGA,CAACA,CAACA,GAAGA,CAACA,GAACA,GAAGA,CAACA,CAACA,GAAGA,CAACA,GAACA,GAAGA,CAACA,CAACA,CAACA;QACnCA,EAAEA,CAACA,CAACA,GAAGA,CAACA,GAACA,GAAGA,CAACA,CAACA,GAAGA,CAACA,GAACA,GAAGA,CAACA,CAACA,GAAGA,CAACA,GAACA,GAAGA,CAACA,CAACA,CAACA;QACnCA,MAAMA,CAACA,EAAEA,CAACA;IACXA,CAACA;IAEDH;;OAEGA;IACIA,uDAAyBA,GAAhCA,UAAiCA,UAAyBA,EAAEA,kBAAqCA,EAAEA,yBAAgCA;QAElII,MAAMA,IAAIA,mBAAmBA,EAAEA,CAACA;IACjCA,CAACA;IAEDJ;;OAEGA;IACIA,yCAAWA,GAAlBA,UAAmBA,aAAsBA,EAAEA,cAAuBA;QAEjEK,IAAIA,CAACA,WAAWA,GAAGA,aAAaA,CAACA;QACjCA,IAAIA,CAACA,YAAYA,GAAGA,cAAcA,CAACA;IACpCA,CAACA;IAEDL;;;;;;;OAOGA;IACIA,oDAAsBA,GAA7BA,UAA8BA,SAAmBA,EAAEA,kBAAqCA,EAAEA,yBAAgCA;QAEzHM,IAAIA,CAACA,WAAWA,CAACA,kBAAkBA,CAACA,gBAAgBA,EAAEA,kBAAkBA,CAACA,iBAAiBA,CAACA,CAACA;QAC5FA,kBAAkBA,CAACA,aAAaA,GAAGA,IAAIA,CAACA;QAExCA,EAAEA,CAACA,CAACA,IAAIA,CAACA,yBAAyBA,CAAkBA,IAAIA,CAACA,wBAAwBA,CAACA,OAAOA,CAACA,SAASA,CAACA,EAAEA,kBAAkBA,EAAEA,yBAAyBA,CAACA,CAACA,CAACA,CAACA;YACtJA,yBAAyBA,GAAGA,kBAAkBA,CAACA,gBAAgBA,CAACA;YAEhEA,kBAAkBA,CAACA,aAAaA,GAAGA,SAASA,CAACA;YAE7CA,MAAMA,CAACA,IAAIA,CAACA;QACbA,CAACA;QAEDA,MAAMA,CAACA,KAAKA,CAACA;IACdA,CAACA;IAEDN;;;;;;;OAOGA;IACIA,+CAAiBA,GAAxBA,UAAyBA,IAASA,EAAEA,kBAAqCA,EAAEA,yBAAgCA,EAAEA,WAAmBA;QAE/HO,IAAIA,CAACA,WAAWA,CAACA,kBAAkBA,CAACA,gBAAgBA,EAAEA,kBAAkBA,CAACA,iBAAiBA,CAACA,CAACA;QAC5FA,kBAAkBA,CAACA,aAAaA,GAAGA,IAAIA,CAACA;QAExCA,IAAIA,OAAgBA,CAACA;QAErBA,IAAIA,GAAGA,GAAUA,IAAIA,CAACA,SAASA,CAACA,MAAMA,CAACA;QACvCA,GAAGA,CAACA,CAACA,GAAGA,CAACA,CAACA,GAAUA,CAACA,EAAEA,CAACA,GAAGA,GAAGA,EAAEA,EAAEA,CAACA,EAAEA,CAACA;YACrCA,OAAOA,GAAGA,IAAIA,CAACA,SAASA,CAACA,CAACA,CAACA,CAACA;YAE5BA,EAAEA,CAACA,CAACA,IAAIA,CAACA,yBAAyBA,CAAkBA,IAAIA,CAACA,sBAAsBA,CAACA,OAAOA,CAACA,OAAOA,CAACA,EAAEA,kBAAkBA,EAAEA,yBAAyBA,CAACA,CAACA,CAACA,CAACA;gBAClJA,yBAAyBA,GAAGA,kBAAkBA,CAACA,gBAAgBA,CAACA;gBAEhEA,kBAAkBA,CAACA,aAAaA,GAAGA,OAAOA,CAACA;gBAE3CA,EAAEA,CAACA,CAACA,CAACA,WAAWA,CAACA;oBAChBA,MAAMA,CAACA,IAAIA,CAACA;YACdA,CAACA;QACFA,CAACA;QAEDA,MAAMA,CAACA,kBAAkBA,CAACA,aAAaA,IAAIA,IAAIA,CAACA;IACjDA,CAACA;IACFP,0BAACA;AAADA,CApHA,AAoHCA,IAAA;AAED,AAA6B,iBAApB,mBAAmB,CAAC","file":"core/pick/PickingColliderBase.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import ISubMesh\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/base/ISubMesh\");\nimport PickingCollisionVO\t\t\t\t= require(\"awayjs-core/lib/core/pick/PickingCollisionVO\");\nimport RenderablePool\t\t\t\t\t= require(\"awayjs-core/lib/core/pool/RenderablePool\");\nimport Point\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Point\");\nimport Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\nimport Billboard\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Billboard\");\nimport Mesh\t\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Mesh\");\nimport AbstractMethodError\t\t\t\t= require(\"awayjs-core/lib/errors/AbstractMethodError\");\n\nimport BillboardRenderable\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/BillboardRenderable\");\nimport RenderableBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/RenderableBase\");\nimport TriangleSubMeshRenderable\t\t= require(\"awayjs-stagegl/lib/core/pool/TriangleSubMeshRenderable\");\n\n/**\n * An abstract base class for all picking collider classes. It should not be instantiated directly.\n *\n * @class away.pick.PickingColliderBase\n */\nclass PickingColliderBase\n{\n\tprivate _billboardRenderablePool:RenderablePool;\n\tprivate _subMeshRenderablePool:RenderablePool;\n\n\tpublic rayPosition:Vector3D;\n\tpublic rayDirection:Vector3D;\n\n\tconstructor()\n\t{\n\t\tthis._billboardRenderablePool = RenderablePool.getPool(BillboardRenderable);\n\t\tthis._subMeshRenderablePool = RenderablePool.getPool(TriangleSubMeshRenderable);\n\t}\n\n\tpublic _pPetCollisionNormal(indexData:Array<number> /*uint*/, vertexData:Array<number>, triangleIndex:number):Vector3D // PROTECTED\n\t{\n\t\tvar normal:Vector3D = new Vector3D();\n\t\tvar i0:number = indexData[ triangleIndex ]*3;\n\t\tvar i1:number = indexData[ triangleIndex + 1 ]*3;\n\t\tvar i2:number = indexData[ triangleIndex + 2 ]*3;\n\t\tvar p0:Vector3D = new Vector3D(vertexData[ i0 ], vertexData[ i0 + 1 ], vertexData[ i0 + 2 ]);\n\t\tvar p1:Vector3D = new Vector3D(vertexData[ i1 ], vertexData[ i1 + 1 ], vertexData[ i1 + 2 ]);\n\t\tvar p2:Vector3D = new Vector3D(vertexData[ i2 ], vertexData[ i2 + 1 ], vertexData[ i2 + 2 ]);\n\t\tvar side0:Vector3D = p1.subtract(p0);\n\t\tvar side1:Vector3D = p2.subtract(p0);\n\t\tnormal = side0.crossProduct(side1);\n\t\tnormal.normalize();\n\t\treturn normal;\n\t}\n\n\tpublic _pGetCollisionUV(indexData:Array<number> /*uint*/, uvData:Array<number>, triangleIndex:number, v:number, w:number, u:number, uvOffset:number, uvStride:number):Point // PROTECTED\n\t{\n\t\tvar uv:Point = new Point();\n\t\tvar uIndex:number = indexData[ triangleIndex ]*uvStride + uvOffset;\n\t\tvar uv0:Vector3D = new Vector3D(uvData[ uIndex ], uvData[ uIndex + 1 ]);\n\t\tuIndex = indexData[ triangleIndex + 1 ]*uvStride + uvOffset;\n\t\tvar uv1:Vector3D = new Vector3D(uvData[ uIndex ], uvData[ uIndex + 1 ]);\n\t\tuIndex = indexData[ triangleIndex + 2 ]*uvStride + uvOffset;\n\t\tvar uv2:Vector3D = new Vector3D(uvData[ uIndex ], uvData[ uIndex + 1 ]);\n\t\tuv.x = u*uv0.x + v*uv1.x + w*uv2.x;\n\t\tuv.y = u*uv0.y + v*uv1.y + w*uv2.y;\n\t\treturn uv;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic _pTestRenderableCollision(renderable:RenderableBase, pickingCollisionVO:PickingCollisionVO, shortestCollisionDistance:number):boolean\n\t{\n\t\tthrow new AbstractMethodError();\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic setLocalRay(localPosition:Vector3D, localDirection:Vector3D)\n\t{\n\t\tthis.rayPosition = localPosition;\n\t\tthis.rayDirection = localDirection;\n\t}\n\n\t/**\n\t * Tests a <code>Billboard</code> object for a collision with the picking ray.\n\t *\n\t * @param billboard The billboard instance to be tested.\n\t * @param pickingCollisionVO The collision object used to store the collision results\n\t * @param shortestCollisionDistance The current value of the shortest distance to a detected collision along the ray.\n\t * @param findClosest\n\t */\n\tpublic testBillboardCollision(billboard:Billboard, pickingCollisionVO:PickingCollisionVO, shortestCollisionDistance:number)\n\t{\n\t\tthis.setLocalRay(pickingCollisionVO.localRayPosition, pickingCollisionVO.localRayDirection);\n\t\tpickingCollisionVO.materialOwner = null;\n\n\t\tif (this._pTestRenderableCollision(<RenderableBase> this._billboardRenderablePool.getItem(billboard), pickingCollisionVO, shortestCollisionDistance)) {\n\t\t\tshortestCollisionDistance = pickingCollisionVO.rayEntryDistance;\n\n\t\t\tpickingCollisionVO.materialOwner = billboard;\n\n\t\t\treturn true;\n\t\t}\n\n\t\treturn false;\n\t}\n\n\t/**\n\t * Tests a <code>Mesh</code> object for a collision with the picking ray.\n\t *\n\t * @param mesh The mesh instance to be tested.\n\t * @param pickingCollisionVO The collision object used to store the collision results\n\t * @param shortestCollisionDistance The current value of the shortest distance to a detected collision along the ray.\n\t * @param findClosest\n\t */\n\tpublic testMeshCollision(mesh:Mesh, pickingCollisionVO:PickingCollisionVO, shortestCollisionDistance:number, findClosest:boolean):boolean\n\t{\n\t\tthis.setLocalRay(pickingCollisionVO.localRayPosition, pickingCollisionVO.localRayDirection);\n\t\tpickingCollisionVO.materialOwner = null;\n\n\t\tvar subMesh:ISubMesh;\n\n\t\tvar len:number = mesh.subMeshes.length;\n\t\tfor (var i:number = 0; i < len; ++i) {\n\t\t\tsubMesh = mesh.subMeshes[i];\n\n\t\t\tif (this._pTestRenderableCollision(<RenderableBase> this._subMeshRenderablePool.getItem(subMesh), pickingCollisionVO, shortestCollisionDistance)) {\n\t\t\t\tshortestCollisionDistance = pickingCollisionVO.rayEntryDistance;\n\n\t\t\t\tpickingCollisionVO.materialOwner = subMesh;\n\n\t\t\t\tif (!findClosest)\n\t\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\treturn pickingCollisionVO.materialOwner != null;\n\t}\n}\n\nexport = PickingColliderBase;"]}
\ No newline at end of file
diff --git a/lib/core/pick/PickingColliderBase.ts b/lib/core/pick/PickingColliderBase.ts
new file mode 100644
index 000000000..448cc19f5
--- /dev/null
+++ b/lib/core/pick/PickingColliderBase.ts
@@ -0,0 +1,137 @@
+import ISubMesh = require("awayjs-core/lib/core/base/ISubMesh");
+import PickingCollisionVO = require("awayjs-core/lib/core/pick/PickingCollisionVO");
+import RenderablePool = require("awayjs-core/lib/core/pool/RenderablePool");
+import Point = require("awayjs-core/lib/core/geom/Point");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import Billboard = require("awayjs-core/lib/entities/Billboard");
+import Mesh = require("awayjs-core/lib/entities/Mesh");
+import AbstractMethodError = require("awayjs-core/lib/errors/AbstractMethodError");
+
+import BillboardRenderable = require("awayjs-stagegl/lib/core/pool/BillboardRenderable");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import TriangleSubMeshRenderable = require("awayjs-stagegl/lib/core/pool/TriangleSubMeshRenderable");
+
+/**
+ * An abstract base class for all picking collider classes. It should not be instantiated directly.
+ *
+ * @class away.pick.PickingColliderBase
+ */
+class PickingColliderBase
+{
+ private _billboardRenderablePool:RenderablePool;
+ private _subMeshRenderablePool:RenderablePool;
+
+ public rayPosition:Vector3D;
+ public rayDirection:Vector3D;
+
+ constructor()
+ {
+ this._billboardRenderablePool = RenderablePool.getPool(BillboardRenderable);
+ this._subMeshRenderablePool = RenderablePool.getPool(TriangleSubMeshRenderable);
+ }
+
+ public _pPetCollisionNormal(indexData:Array /*uint*/, vertexData:Array, triangleIndex:number):Vector3D // PROTECTED
+ {
+ var normal:Vector3D = new Vector3D();
+ var i0:number = indexData[ triangleIndex ]*3;
+ var i1:number = indexData[ triangleIndex + 1 ]*3;
+ var i2:number = indexData[ triangleIndex + 2 ]*3;
+ var p0:Vector3D = new Vector3D(vertexData[ i0 ], vertexData[ i0 + 1 ], vertexData[ i0 + 2 ]);
+ var p1:Vector3D = new Vector3D(vertexData[ i1 ], vertexData[ i1 + 1 ], vertexData[ i1 + 2 ]);
+ var p2:Vector3D = new Vector3D(vertexData[ i2 ], vertexData[ i2 + 1 ], vertexData[ i2 + 2 ]);
+ var side0:Vector3D = p1.subtract(p0);
+ var side1:Vector3D = p2.subtract(p0);
+ normal = side0.crossProduct(side1);
+ normal.normalize();
+ return normal;
+ }
+
+ public _pGetCollisionUV(indexData:Array /*uint*/, uvData:Array, triangleIndex:number, v:number, w:number, u:number, uvOffset:number, uvStride:number):Point // PROTECTED
+ {
+ var uv:Point = new Point();
+ var uIndex:number = indexData[ triangleIndex ]*uvStride + uvOffset;
+ var uv0:Vector3D = new Vector3D(uvData[ uIndex ], uvData[ uIndex + 1 ]);
+ uIndex = indexData[ triangleIndex + 1 ]*uvStride + uvOffset;
+ var uv1:Vector3D = new Vector3D(uvData[ uIndex ], uvData[ uIndex + 1 ]);
+ uIndex = indexData[ triangleIndex + 2 ]*uvStride + uvOffset;
+ var uv2:Vector3D = new Vector3D(uvData[ uIndex ], uvData[ uIndex + 1 ]);
+ uv.x = u*uv0.x + v*uv1.x + w*uv2.x;
+ uv.y = u*uv0.y + v*uv1.y + w*uv2.y;
+ return uv;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public _pTestRenderableCollision(renderable:RenderableBase, pickingCollisionVO:PickingCollisionVO, shortestCollisionDistance:number):boolean
+ {
+ throw new AbstractMethodError();
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public setLocalRay(localPosition:Vector3D, localDirection:Vector3D)
+ {
+ this.rayPosition = localPosition;
+ this.rayDirection = localDirection;
+ }
+
+ /**
+ * Tests a Billboard
object for a collision with the picking ray.
+ *
+ * @param billboard The billboard instance to be tested.
+ * @param pickingCollisionVO The collision object used to store the collision results
+ * @param shortestCollisionDistance The current value of the shortest distance to a detected collision along the ray.
+ * @param findClosest
+ */
+ public testBillboardCollision(billboard:Billboard, pickingCollisionVO:PickingCollisionVO, shortestCollisionDistance:number)
+ {
+ this.setLocalRay(pickingCollisionVO.localRayPosition, pickingCollisionVO.localRayDirection);
+ pickingCollisionVO.materialOwner = null;
+
+ if (this._pTestRenderableCollision( this._billboardRenderablePool.getItem(billboard), pickingCollisionVO, shortestCollisionDistance)) {
+ shortestCollisionDistance = pickingCollisionVO.rayEntryDistance;
+
+ pickingCollisionVO.materialOwner = billboard;
+
+ return true;
+ }
+
+ return false;
+ }
+
+ /**
+ * Tests a Mesh
object for a collision with the picking ray.
+ *
+ * @param mesh The mesh instance to be tested.
+ * @param pickingCollisionVO The collision object used to store the collision results
+ * @param shortestCollisionDistance The current value of the shortest distance to a detected collision along the ray.
+ * @param findClosest
+ */
+ public testMeshCollision(mesh:Mesh, pickingCollisionVO:PickingCollisionVO, shortestCollisionDistance:number, findClosest:boolean):boolean
+ {
+ this.setLocalRay(pickingCollisionVO.localRayPosition, pickingCollisionVO.localRayDirection);
+ pickingCollisionVO.materialOwner = null;
+
+ var subMesh:ISubMesh;
+
+ var len:number = mesh.subMeshes.length;
+ for (var i:number = 0; i < len; ++i) {
+ subMesh = mesh.subMeshes[i];
+
+ if (this._pTestRenderableCollision( this._subMeshRenderablePool.getItem(subMesh), pickingCollisionVO, shortestCollisionDistance)) {
+ shortestCollisionDistance = pickingCollisionVO.rayEntryDistance;
+
+ pickingCollisionVO.materialOwner = subMesh;
+
+ if (!findClosest)
+ return true;
+ }
+ }
+
+ return pickingCollisionVO.materialOwner != null;
+ }
+}
+
+export = PickingColliderBase;
\ No newline at end of file
diff --git a/lib/core/pick/ShaderPicker.js b/lib/core/pick/ShaderPicker.js
new file mode 100755
index 000000000..8c2b5aae5
--- /dev/null
+++ b/lib/core/pick/ShaderPicker.js
@@ -0,0 +1,415 @@
+var Debug = require("awayjs-core/lib/utils/Debug");
+var BitmapData = require("awayjs-core/lib/core/base/BitmapData");
+var TriangleSubGeometry = require("awayjs-core/lib/core/base/TriangleSubGeometry");
+var Matrix3DUtils = require("awayjs-core/lib/core/geom/Matrix3DUtils");
+var Point = require("awayjs-core/lib/core/geom/Point");
+var Rectangle = require("awayjs-core/lib/core/geom/Rectangle");
+var Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+var AGALMiniAssembler = require("awayjs-stagegl/lib/aglsl/assembler/AGALMiniAssembler");
+var ContextGLBlendFactor = require("awayjs-stagegl/lib/core/stagegl/ContextGLBlendFactor");
+var ContextGLClearMask = require("awayjs-stagegl/lib/core/stagegl/ContextGLClearMask");
+var ContextGLCompareMode = require("awayjs-stagegl/lib/core/stagegl/ContextGLCompareMode");
+var ContextGLProgramType = require("awayjs-stagegl/lib/core/stagegl/ContextGLProgramType");
+var ContextGLTriangleFace = require("awayjs-stagegl/lib/core/stagegl/ContextGLTriangleFace");
+/**
+ * Picks a 3d object from a view or scene by performing a separate render pass on the scene around the area being picked using key color values,
+ * then reading back the color value of the pixel in the render representing the picking ray. Requires multiple passes and readbacks for retriving details
+ * on an entity that has its shaderPickingDetails property set to true.
+ *
+ * A read-back operation from any GPU is not a very efficient process, and the amount of processing used can vary significantly between different hardware.
+ *
+ * @see away.entities.Entity#shaderPickingDetails
+ *
+ * @class away.pick.ShaderPicker
+ */
+var ShaderPicker = (function () {
+ /**
+ * Creates a new ShaderPicker
object.
+ *
+ * @param shaderPickingDetails Determines whether the picker includes a second pass to calculate extra
+ * properties such as uv and normal coordinates.
+ */
+ function ShaderPicker(shaderPickingDetails) {
+ if (shaderPickingDetails === void 0) { shaderPickingDetails = false; }
+ this._onlyMouseEnabled = true;
+ this._interactives = new Array();
+ this._localHitPosition = new Vector3D();
+ this._hitUV = new Point();
+ this._localHitNormal = new Vector3D();
+ this._rayPos = new Vector3D();
+ this._rayDir = new Vector3D();
+ this._shaderPickingDetails = shaderPickingDetails;
+ this._id = new Array(4);
+ this._viewportData = new Array(4); // first 2 contain scale, last 2 translation
+ this._boundOffsetScale = new Array(8); // first 2 contain scale, last 2 translation
+ this._boundOffsetScale[3] = 0;
+ this._boundOffsetScale[7] = 1;
+ }
+ Object.defineProperty(ShaderPicker.prototype, "onlyMouseEnabled", {
+ /**
+ * @inheritDoc
+ */
+ get: function () {
+ return this._onlyMouseEnabled;
+ },
+ set: function (value) {
+ this._onlyMouseEnabled = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ ShaderPicker.prototype.getViewCollision = function (x, y, view) {
+ var collector = view.iEntityCollector;
+ this._stage = view.renderer.stage;
+ if (!this._stage)
+ return null;
+ this._context = this._stage.context;
+ this._viewportData[0] = view.width;
+ this._viewportData[1] = view.height;
+ this._viewportData[2] = -(this._projX = 2 * x / view.width - 1);
+ this._viewportData[3] = this._projY = 2 * y / view.height - 1;
+ // _potentialFound will be set to true if any object is actually rendered
+ this._potentialFound = false;
+ //reset head values
+ this._blendedRenderableHead = null;
+ this._opaqueRenderableHead = null;
+ this.pDraw(collector, null);
+ // clear buffers
+ this._context.setVertexBufferAt(0, null);
+ if (!this._context || !this._potentialFound)
+ return null;
+ if (!this._bitmapData)
+ this._bitmapData = new BitmapData(1, 1, false, 0);
+ this._context.drawToBitmapData(this._bitmapData);
+ this._hitColor = this._bitmapData.getPixel(0, 0);
+ if (!this._hitColor) {
+ this._context.present();
+ return null;
+ }
+ this._hitRenderable = this._interactives[this._hitColor - 1];
+ this._hitEntity = this._hitRenderable.sourceEntity;
+ if (this._onlyMouseEnabled && !this._hitEntity._iIsMouseEnabled())
+ return null;
+ var _collisionVO = this._hitEntity._iPickingCollisionVO;
+ if (this._shaderPickingDetails) {
+ this.getHitDetails(view.camera);
+ _collisionVO.localPosition = this._localHitPosition;
+ _collisionVO.localNormal = this._localHitNormal;
+ _collisionVO.uv = this._hitUV;
+ _collisionVO.index = this._faceIndex;
+ }
+ else {
+ _collisionVO.localPosition = null;
+ _collisionVO.localNormal = null;
+ _collisionVO.uv = null;
+ _collisionVO.index = 0;
+ }
+ return _collisionVO;
+ };
+ //*/
+ /**
+ * @inheritDoc
+ */
+ ShaderPicker.prototype.getSceneCollision = function (position, direction, scene) {
+ return null;
+ };
+ /**
+ * @inheritDoc
+ */
+ ShaderPicker.prototype.pDraw = function (entityCollector, target) {
+ var camera = entityCollector.camera;
+ this._context.clear(0, 0, 0, 1);
+ this._stage.scissorRect = ShaderPicker.MOUSE_SCISSOR_RECT;
+ this._interactives.length = this._interactiveId = 0;
+ if (!this._objectProgram)
+ this.initObjectProgram();
+ this._context.setBlendFactors(ContextGLBlendFactor.ONE, ContextGLBlendFactor.ZERO);
+ this._context.setDepthTest(true, ContextGLCompareMode.LESS);
+ this._context.setProgram(this._objectProgram);
+ this._context.setProgramConstantsFromArray(ContextGLProgramType.VERTEX, 4, this._viewportData, 1);
+ //this.drawRenderables(entityCollector.opaqueRenderableHead, camera);
+ //this.drawRenderables(entityCollector.blendedRenderableHead, camera);
+ //TODO: reimplement ShaderPicker inheriting from RendererBase
+ };
+ /**
+ * Draw a list of renderables.
+ * @param renderables The renderables to draw.
+ * @param camera The camera for which to render.
+ */
+ ShaderPicker.prototype.drawRenderables = function (renderable, camera) {
+ var matrix = Matrix3DUtils.CALCULATION_MATRIX;
+ var viewProjection = camera.viewProjection;
+ while (renderable) {
+ // it's possible that the renderable was already removed from the scene
+ if (!renderable.sourceEntity.scene || !renderable.sourceEntity._iIsMouseEnabled()) {
+ renderable = renderable.next;
+ continue;
+ }
+ this._potentialFound = true;
+ this._context.setCulling(renderable.materialOwner.material.bothSides ? ContextGLTriangleFace.NONE : ContextGLTriangleFace.BACK, camera.projection.coordinateSystem);
+ this._interactives[this._interactiveId++] = renderable;
+ // color code so that reading from bitmapdata will contain the correct value
+ this._id[1] = (this._interactiveId >> 8) / 255; // on green channel
+ this._id[2] = (this._interactiveId & 0xff) / 255; // on blue channel
+ matrix.copyFrom(renderable.sourceEntity.getRenderSceneTransform(camera));
+ matrix.append(viewProjection);
+ this._context.setProgramConstantsFromMatrix(ContextGLProgramType.VERTEX, 0, matrix, true);
+ this._context.setProgramConstantsFromArray(ContextGLProgramType.FRAGMENT, 0, this._id, 1);
+ this._context.activateBuffer(0, renderable.getVertexData(TriangleSubGeometry.POSITION_DATA), renderable.getVertexOffset(TriangleSubGeometry.POSITION_DATA), TriangleSubGeometry.POSITION_FORMAT);
+ this._context.drawTriangles(this._context.getIndexBuffer(renderable.getIndexData()), 0, renderable.numTriangles);
+ renderable = renderable.next;
+ }
+ };
+ ShaderPicker.prototype.updateRay = function (camera) {
+ this._rayPos = camera.scenePosition;
+ this._rayDir = camera.getRay(this._projX, this._projY, 1);
+ this._rayDir.normalize();
+ };
+ /**
+ * Creates the Program that color-codes objects.
+ */
+ ShaderPicker.prototype.initObjectProgram = function () {
+ var vertexCode;
+ var fragmentCode;
+ this._objectProgram = this._context.createProgram();
+ vertexCode = "m44 vt0, va0, vc0 \n" + "mul vt1.xy, vt0.w, vc4.zw \n" + "add vt0.xy, vt0.xy, vt1.xy \n" + "mul vt0.xy, vt0.xy, vc4.xy \n" + "mov op, vt0 \n";
+ fragmentCode = "mov oc, fc0"; // write identifier
+ Debug.throwPIR('ShaderPicker', 'initTriangleProgram', 'Dependency: initObjectProgram');
+ //_objectProgram.upload(new AGALMiniAssembler().assemble(ContextGLProgramType.VERTEX, vertexCode),new AGALMiniAssembler().assemble(ContextGLProgramType.FRAGMENT, fragmentCode));
+ };
+ /**
+ * Creates the Program that renders positions.
+ */
+ ShaderPicker.prototype.initTriangleProgram = function () {
+ var vertexCode;
+ var fragmentCode;
+ this._triangleProgram = this._context.createProgram();
+ // todo: add animation code
+ vertexCode = "add vt0, va0, vc5 \n" + "mul vt0, vt0, vc6 \n" + "mov v0, vt0 \n" + "m44 vt0, va0, vc0 \n" + "mul vt1.xy, vt0.w, vc4.zw \n" + "add vt0.xy, vt0.xy, vt1.xy \n" + "mul vt0.xy, vt0.xy, vc4.xy \n" + "mov op, vt0 \n";
+ fragmentCode = "mov oc, v0"; // write identifier
+ var vertexByteCode = (new AGALMiniAssembler().assemble("part vertex 1\n" + vertexCode + "endpart"))['vertex'].data;
+ var fragmentByteCode = (new AGALMiniAssembler().assemble("part fragment 1\n" + fragmentCode + "endpart"))['fragment'].data;
+ this._triangleProgram.upload(vertexByteCode, fragmentByteCode);
+ };
+ /**
+ * Gets more detailed information about the hir position, if required.
+ * @param camera The camera used to view the hit object.
+ */
+ ShaderPicker.prototype.getHitDetails = function (camera) {
+ this.getApproximatePosition(camera);
+ this.getPreciseDetails(camera);
+ };
+ /**
+ * Finds a first-guess approximate position about the hit position.
+ *
+ * @param camera The camera used to view the hit object.
+ */
+ ShaderPicker.prototype.getApproximatePosition = function (camera) {
+ var bounds = this._hitRenderable.sourceEntity.bounds.aabb;
+ var col;
+ var scX, scY, scZ;
+ var offsX, offsY, offsZ;
+ var localViewProjection = Matrix3DUtils.CALCULATION_MATRIX;
+ localViewProjection.copyFrom(this._hitRenderable.sourceEntity.getRenderSceneTransform(camera));
+ localViewProjection.append(camera.viewProjection);
+ if (!this._triangleProgram) {
+ this.initTriangleProgram();
+ }
+ this._boundOffsetScale[4] = 1 / (scX = bounds.width);
+ this._boundOffsetScale[5] = 1 / (scY = bounds.height);
+ this._boundOffsetScale[6] = 1 / (scZ = bounds.depth);
+ this._boundOffsetScale[0] = offsX = -bounds.x;
+ this._boundOffsetScale[1] = offsY = -bounds.y;
+ this._boundOffsetScale[2] = offsZ = -bounds.z;
+ this._context.setProgram(this._triangleProgram);
+ this._context.clear(0, 0, 0, 0, 1, 0, ContextGLClearMask.DEPTH);
+ this._context.setScissorRectangle(ShaderPicker.MOUSE_SCISSOR_RECT);
+ this._context.setProgramConstantsFromMatrix(ContextGLProgramType.VERTEX, 0, localViewProjection, true);
+ this._context.setProgramConstantsFromArray(ContextGLProgramType.VERTEX, 5, this._boundOffsetScale, 2);
+ this._context.activateBuffer(0, this._hitRenderable.getVertexData(TriangleSubGeometry.POSITION_DATA), this._hitRenderable.getVertexOffset(TriangleSubGeometry.POSITION_DATA), TriangleSubGeometry.POSITION_FORMAT);
+ this._context.drawTriangles(this._context.getIndexBuffer(this._hitRenderable.getIndexData()), 0, this._hitRenderable.numTriangles);
+ this._context.drawToBitmapData(this._bitmapData);
+ col = this._bitmapData.getPixel(0, 0);
+ this._localHitPosition.x = ((col >> 16) & 0xff) * scX / 255 - offsX;
+ this._localHitPosition.y = ((col >> 8) & 0xff) * scY / 255 - offsY;
+ this._localHitPosition.z = (col & 0xff) * scZ / 255 - offsZ;
+ };
+ /**
+ * Use the approximate position info to find the face under the mouse position from which we can derive the precise
+ * ray-face intersection point, then use barycentric coordinates to figure out the uv coordinates, etc.
+ * @param camera The camera used to view the hit object.
+ */
+ ShaderPicker.prototype.getPreciseDetails = function (camera) {
+ var len = indices.length;
+ var x1, y1, z1;
+ var x2, y2, z2;
+ var x3, y3, z3;
+ var i = 0, j = 1, k = 2;
+ var t1, t2, t3;
+ var v0x, v0y, v0z;
+ var v1x, v1y, v1z;
+ var v2x, v2y, v2z;
+ var ni1, ni2, ni3;
+ var n1, n2, n3, nLength;
+ var dot00, dot01, dot02, dot11, dot12;
+ var s, t, invDenom;
+ var x = this._localHitPosition.x, y = this._localHitPosition.y, z = this._localHitPosition.z;
+ var u, v;
+ var ui1, ui2, ui3;
+ var s0x, s0y, s0z;
+ var s1x, s1y, s1z;
+ var nl;
+ var indices = this._hitRenderable.getIndexData().data;
+ var positions = this._hitRenderable.getVertexData(TriangleSubGeometry.POSITION_DATA).data;
+ var positionStride = this._hitRenderable.getVertexData(TriangleSubGeometry.POSITION_DATA).dataPerVertex;
+ var positionOffset = this._hitRenderable.getVertexOffset(TriangleSubGeometry.POSITION_DATA);
+ var uvs = this._hitRenderable.getVertexData(TriangleSubGeometry.UV_DATA).data;
+ var uvStride = this._hitRenderable.getVertexData(TriangleSubGeometry.UV_DATA).dataPerVertex;
+ var uvOffset = this._hitRenderable.getVertexOffset(TriangleSubGeometry.UV_DATA);
+ var normals = this._hitRenderable.getVertexData(TriangleSubGeometry.NORMAL_DATA).data;
+ var normalStride = this._hitRenderable.getVertexData(TriangleSubGeometry.NORMAL_DATA).dataPerVertex;
+ var normalOffset = this._hitRenderable.getVertexOffset(TriangleSubGeometry.NORMAL_DATA);
+ this.updateRay(camera);
+ while (i < len) {
+ t1 = positionOffset + indices[i] * positionStride;
+ t2 = positionOffset + indices[j] * positionStride;
+ t3 = positionOffset + indices[k] * positionStride;
+ x1 = positions[t1];
+ y1 = positions[t1 + 1];
+ z1 = positions[t1 + 2];
+ x2 = positions[t2];
+ y2 = positions[t2 + 1];
+ z2 = positions[t2 + 2];
+ x3 = positions[t3];
+ y3 = positions[t3 + 1];
+ z3 = positions[t3 + 2];
+ // if within bounds
+ if (!((x < x1 && x < x2 && x < x3) || (y < y1 && y < y2 && y < y3) || (z < z1 && z < z2 && z < z3) || (x > x1 && x > x2 && x > x3) || (y > y1 && y > y2 && y > y3) || (z > z1 && z > z2 && z > z3))) {
+ // calculate barycentric coords for approximated position
+ v0x = x3 - x1;
+ v0y = y3 - y1;
+ v0z = z3 - z1;
+ v1x = x2 - x1;
+ v1y = y2 - y1;
+ v1z = z2 - z1;
+ v2x = x - x1;
+ v2y = y - y1;
+ v2z = z - z1;
+ dot00 = v0x * v0x + v0y * v0y + v0z * v0z;
+ dot01 = v0x * v1x + v0y * v1y + v0z * v1z;
+ dot02 = v0x * v2x + v0y * v2y + v0z * v2z;
+ dot11 = v1x * v1x + v1y * v1y + v1z * v1z;
+ dot12 = v1x * v2x + v1y * v2y + v1z * v2z;
+ invDenom = 1 / (dot00 * dot11 - dot01 * dot01);
+ s = (dot11 * dot02 - dot01 * dot12) * invDenom;
+ t = (dot00 * dot12 - dot01 * dot02) * invDenom;
+ // if inside the current triangle, fetch details hit information
+ if (s >= 0 && t >= 0 && (s + t) <= 1) {
+ ni1 = normalOffset + indices[i] * normalStride;
+ ni2 = normalOffset + indices[j] * normalStride;
+ ni3 = normalOffset + indices[k] * normalStride;
+ n1 = indices[ni1] + indices[ni2] + indices[ni3];
+ n2 = indices[ni1 + 1] + indices[ni2 + 1] + indices[ni3 + 1];
+ n3 = indices[ni1 + 2] + indices[ni2 + 2] + indices[ni3 + 2];
+ nLength = Math.sqrt(n1 * n1 + n2 * n2 + n3 * n3);
+ n1 /= nLength;
+ n2 /= nLength;
+ n3 /= nLength;
+ // this is def the triangle, now calculate precise coords
+ this.getPrecisePosition(this._hitRenderable.sourceEntity.inverseSceneTransform, n1, n2, n3, x1, y1, z1);
+ v2x = this._localHitPosition.x - x1;
+ v2y = this._localHitPosition.y - y1;
+ v2z = this._localHitPosition.z - z1;
+ s0x = x2 - x1; // s0 = p1 - p0
+ s0y = y2 - y1;
+ s0z = z2 - z1;
+ s1x = x3 - x1; // s1 = p2 - p0
+ s1y = y3 - y1;
+ s1z = z3 - z1;
+ this._localHitNormal.x = s0y * s1z - s0z * s1y; // n = s0 x s1
+ this._localHitNormal.y = s0z * s1x - s0x * s1z;
+ this._localHitNormal.z = s0x * s1y - s0y * s1x;
+ nl = 1 / Math.sqrt(this._localHitNormal.x * this._localHitNormal.x + this._localHitNormal.y * this._localHitNormal.y + this._localHitNormal.z * this._localHitNormal.z); // normalize n
+ this._localHitNormal.x *= nl;
+ this._localHitNormal.y *= nl;
+ this._localHitNormal.z *= nl;
+ dot02 = v0x * v2x + v0y * v2y + v0z * v2z;
+ dot12 = v1x * v2x + v1y * v2y + v1z * v2z;
+ s = (dot11 * dot02 - dot01 * dot12) * invDenom;
+ t = (dot00 * dot12 - dot01 * dot02) * invDenom;
+ ui1 = uvOffset + indices[i] * uvStride;
+ ui2 = uvOffset + indices[j] * uvStride;
+ ui3 = uvOffset + indices[k] * uvStride;
+ u = uvs[ui1];
+ v = uvs[ui1 + 1];
+ this._hitUV.x = u + t * (uvs[ui2] - u) + s * (uvs[ui3] - u);
+ this._hitUV.y = v + t * (uvs[ui2 + 1] - v) + s * (uvs[ui3 + 1] - v);
+ this._faceIndex = i;
+ //TODO add back subGeometryIndex value
+ //this._subGeometryIndex = away.utils.GeometryUtils.getMeshSubGeometryIndex(subGeom);
+ return;
+ }
+ }
+ i += 3;
+ j += 3;
+ k += 3;
+ }
+ };
+ /**
+ * Finds the precise hit position by unprojecting the screen coordinate back unto the hit face's plane and
+ * calculating the intersection point.
+ * @param camera The camera used to render the object.
+ * @param invSceneTransform The inverse scene transformation of the hit object.
+ * @param nx The x-coordinate of the face's plane normal.
+ * @param ny The y-coordinate of the face plane normal.
+ * @param nz The z-coordinate of the face plane normal.
+ * @param px The x-coordinate of a point on the face's plane (ie a face vertex)
+ * @param py The y-coordinate of a point on the face's plane (ie a face vertex)
+ * @param pz The z-coordinate of a point on the face's plane (ie a face vertex)
+ */
+ ShaderPicker.prototype.getPrecisePosition = function (invSceneTransform, nx, ny, nz, px, py, pz) {
+ // calculate screen ray and find exact intersection position with triangle
+ var rx, ry, rz;
+ var ox, oy, oz;
+ var t;
+ var raw = Matrix3DUtils.RAW_DATA_CONTAINER;
+ var cx = this._rayPos.x, cy = this._rayPos.y, cz = this._rayPos.z;
+ // unprojected projection point, gives ray dir in cam space
+ ox = this._rayDir.x;
+ oy = this._rayDir.y;
+ oz = this._rayDir.z;
+ // transform ray dir and origin (cam pos) to object space
+ //invSceneTransform.copyRawDataTo( raw );
+ invSceneTransform.copyRawDataTo(raw);
+ rx = raw[0] * ox + raw[4] * oy + raw[8] * oz;
+ ry = raw[1] * ox + raw[5] * oy + raw[9] * oz;
+ rz = raw[2] * ox + raw[6] * oy + raw[10] * oz;
+ ox = raw[0] * cx + raw[4] * cy + raw[8] * cz + raw[12];
+ oy = raw[1] * cx + raw[5] * cy + raw[9] * cz + raw[13];
+ oz = raw[2] * cx + raw[6] * cy + raw[10] * cz + raw[14];
+ t = ((px - ox) * nx + (py - oy) * ny + (pz - oz) * nz) / (rx * nx + ry * ny + rz * nz);
+ this._localHitPosition.x = ox + rx * t;
+ this._localHitPosition.y = oy + ry * t;
+ this._localHitPosition.z = oz + rz * t;
+ };
+ ShaderPicker.prototype.dispose = function () {
+ this._bitmapData.dispose();
+ if (this._triangleProgram)
+ this._triangleProgram.dispose();
+ if (this._objectProgram)
+ this._objectProgram.dispose();
+ this._triangleProgram = null;
+ this._objectProgram = null;
+ this._bitmapData = null;
+ this._hitRenderable = null;
+ this._hitEntity = null;
+ };
+ ShaderPicker.MOUSE_SCISSOR_RECT = new Rectangle(0, 0, 1, 1);
+ return ShaderPicker;
+})();
+module.exports = ShaderPicker;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["core/pick/shaderpicker.ts"],"names":["ShaderPicker","ShaderPicker.constructor","ShaderPicker.onlyMouseEnabled","ShaderPicker.getViewCollision","ShaderPicker.getSceneCollision","ShaderPicker.pDraw","ShaderPicker.drawRenderables","ShaderPicker.updateRay","ShaderPicker.initObjectProgram","ShaderPicker.initTriangleProgram","ShaderPicker.getHitDetails","ShaderPicker.getApproximatePosition","ShaderPicker.getPreciseDetails","ShaderPicker.getPrecisePosition","ShaderPicker.dispose"],"mappings":"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","file":"core/pick/ShaderPicker.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Debug\t\t\t\t\t\t\t= require(\"awayjs-core/lib/utils/Debug\");\nimport BitmapData\t\t\t\t\t\t= require(\"awayjs-core/lib/core/base/BitmapData\");\nimport TriangleSubGeometry\t\t\t\t= require(\"awayjs-core/lib/core/base/TriangleSubGeometry\");\nimport Scene\t\t\t\t\t\t\t= require(\"awayjs-core/lib/containers/Scene\");\nimport View\t\t\t\t\t\t\t\t= require(\"awayjs-core/lib/containers/View\");\nimport Box\t\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Box\");\nimport Matrix3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Matrix3D\");\nimport Matrix3DUtils\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Matrix3DUtils\");\nimport Point\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Point\");\nimport Rectangle\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Rectangle\");\nimport Vector3D\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/geom/Vector3D\");\nimport IPicker\t\t\t\t\t\t\t= require(\"awayjs-core/lib/core/pick/IPicker\");\nimport PickingCollisionVO\t\t\t\t= require(\"awayjs-core/lib/core/pick/PickingCollisionVO\");\nimport EntityCollector\t\t\t\t\t= require(\"awayjs-core/lib/core/traverse/EntityCollector\");\nimport Camera\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Camera\");\nimport IEntity\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/IEntity\");\nimport MaterialBase\t\t\t\t\t\t= require(\"awayjs-core/lib/materials/MaterialBase\");\nimport ByteArray\t\t\t\t\t\t= require(\"awayjs-core/lib/utils/ByteArray\");\n\nimport AGALMiniAssembler\t\t\t\t= require(\"awayjs-stagegl/lib/aglsl/assembler/AGALMiniAssembler\");\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport RenderableBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/RenderableBase\");\nimport DefaultRenderer\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/render/DefaultRenderer\");\nimport ContextGLBlendFactor\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/ContextGLBlendFactor\");\nimport ContextGLClearMask\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/ContextGLClearMask\");\nimport ContextGLCompareMode\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/ContextGLCompareMode\");\nimport ContextGLProgramType\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/ContextGLProgramType\");\nimport ContextGLTriangleFace\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/ContextGLTriangleFace\");\nimport IContextStageGL\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/IContextStageGL\");\nimport IProgram\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/IProgram\");\nimport ITextureBase\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/ITextureBase\");\n\n/**\n * Picks a 3d object from a view or scene by performing a separate render pass on the scene around the area being picked using key color values,\n * then reading back the color value of the pixel in the render representing the picking ray. Requires multiple passes and readbacks for retriving details\n * on an entity that has its shaderPickingDetails property set to true.\n *\n * A read-back operation from any GPU is not a very efficient process, and the amount of processing used can vary significantly between different hardware.\n *\n * @see away.entities.Entity#shaderPickingDetails\n *\n * @class away.pick.ShaderPicker\n */\nclass ShaderPicker implements IPicker\n{\n\tprivate _opaqueRenderableHead:RenderableBase;\n\tprivate _blendedRenderableHead:RenderableBase;\n\n\tprivate _stage:Stage;\n\tprivate _context:IContextStageGL;\n\tprivate _onlyMouseEnabled:boolean = true;\n\n\tprivate _objectProgram:IProgram;\n\tprivate _triangleProgram:IProgram;\n\tprivate _bitmapData:BitmapData;\n\tprivate _viewportData:Array<number>;\n\tprivate _boundOffsetScale:Array<number>;\n\tprivate _id:Array<number>;\n\n\tprivate _interactives:Array<RenderableBase> = new Array<RenderableBase>();\n\tprivate _interactiveId:number;\n\tprivate _hitColor:number;\n\tprivate _projX:number;\n\tprivate _projY:number;\n\n\tprivate _hitRenderable:RenderableBase;\n\tprivate _hitEntity:IEntity;\n\tprivate _localHitPosition:Vector3D = new Vector3D();\n\tprivate _hitUV:Point = new Point();\n\tprivate _faceIndex:number;\n\tprivate _subGeometryIndex:number;\n\n\tprivate _localHitNormal:Vector3D = new Vector3D();\n\n\tprivate _rayPos:Vector3D = new Vector3D();\n\tprivate _rayDir:Vector3D = new Vector3D();\n\tprivate _potentialFound:boolean;\n\tprivate static MOUSE_SCISSOR_RECT:Rectangle = new Rectangle(0, 0, 1, 1);\n\n\tprivate _shaderPickingDetails:boolean;\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic get onlyMouseEnabled():boolean\n\t{\n\t\treturn this._onlyMouseEnabled;\n\t}\n\n\tpublic set onlyMouseEnabled(value:boolean)\n\t{\n\t\tthis._onlyMouseEnabled = value;\n\t}\n\n\t/**\n\t * Creates a new <code>ShaderPicker</code> object.\n\t *\n\t * @param shaderPickingDetails Determines whether the picker includes a second pass to calculate extra\n\t * properties such as uv and normal coordinates.\n\t */\n\tconstructor(shaderPickingDetails:boolean = false)\n\t{\n\t\tthis._shaderPickingDetails = shaderPickingDetails;\n\n\t\tthis._id = new Array<number>(4);\n\t\tthis._viewportData = new Array<number>(4); // first 2 contain scale, last 2 translation\n\t\tthis._boundOffsetScale = new Array<number>(8); // first 2 contain scale, last 2 translation\n\t\tthis._boundOffsetScale[3] = 0;\n\t\tthis._boundOffsetScale[7] = 1;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getViewCollision(x:number, y:number, view:View):PickingCollisionVO\n\t{\n\t\tvar collector:EntityCollector = <EntityCollector> view.iEntityCollector;\n\n\t\tthis._stage = (<DefaultRenderer> view.renderer).stage;\n\n\t\tif (!this._stage)\n\t\t\treturn null;\n\n\t\tthis._context = <IContextStageGL> this._stage.context;\n\n\t\tthis._viewportData[0] = view.width;\n\t\tthis._viewportData[1] = view.height;\n\t\tthis._viewportData[2] = -(this._projX = 2*x/view.width - 1);\n\t\tthis._viewportData[3] = this._projY = 2*y/view.height - 1;\n\n\t\t// _potentialFound will be set to true if any object is actually rendered\n\t\tthis._potentialFound = false;\n\n\t\t//reset head values\n\t\tthis._blendedRenderableHead = null;\n\t\tthis._opaqueRenderableHead = null;\n\n\t\tthis.pDraw(collector, null);\n\n\t\t// clear buffers\n\t\tthis._context.setVertexBufferAt(0, null);\n\n\t\tif (!this._context || !this._potentialFound)\n\t\t\treturn null;\n\n\t\tif (!this._bitmapData)\n\t\t\tthis._bitmapData = new BitmapData(1, 1, false, 0);\n\n\t\tthis._context.drawToBitmapData(this._bitmapData);\n\t\tthis._hitColor = this._bitmapData.getPixel(0, 0);\n\n\t\tif (!this._hitColor) {\n\t\t\tthis._context.present();\n\t\t\treturn null;\n\t\t}\n\n\t\tthis._hitRenderable = this._interactives[this._hitColor - 1];\n\t\tthis._hitEntity = this._hitRenderable.sourceEntity;\n\n\t\tif (this._onlyMouseEnabled && !this._hitEntity._iIsMouseEnabled())\n\t\t\treturn null;\n\n\t\tvar _collisionVO:PickingCollisionVO = this._hitEntity._iPickingCollisionVO;\n\t\tif (this._shaderPickingDetails) {\n\t\t\tthis.getHitDetails(view.camera);\n\t\t\t_collisionVO.localPosition = this._localHitPosition;\n\t\t\t_collisionVO.localNormal = this._localHitNormal;\n\t\t\t_collisionVO.uv = this._hitUV;\n\t\t\t_collisionVO.index = this._faceIndex;\n\t\t\t//_collisionVO.subGeometryIndex = this._subGeometryIndex;\n\n\t\t} else {\n\t\t\t_collisionVO.localPosition = null;\n\t\t\t_collisionVO.localNormal = null;\n\t\t\t_collisionVO.uv = null;\n\t\t\t_collisionVO.index = 0;\n\t\t\t//_collisionVO.subGeometryIndex = 0;\n\t\t}\n\n\t\treturn _collisionVO;\n\t}\n\n\t//*/\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic getSceneCollision(position:Vector3D, direction:Vector3D, scene:Scene):PickingCollisionVO\n\t{\n\t\treturn null;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic pDraw(entityCollector:EntityCollector, target:ITextureBase)\n\t{\n\n\t\tvar camera:Camera = entityCollector.camera;\n\n\t\tthis._context.clear(0, 0, 0, 1);\n\t\tthis._stage.scissorRect = ShaderPicker.MOUSE_SCISSOR_RECT;\n\n\t\tthis._interactives.length = this._interactiveId = 0;\n\n\t\tif (!this._objectProgram)\n\t\t\tthis.initObjectProgram();\n\n\t\tthis._context.setBlendFactors(ContextGLBlendFactor.ONE, ContextGLBlendFactor.ZERO);\n\t\tthis._context.setDepthTest(true, ContextGLCompareMode.LESS);\n\t\tthis._context.setProgram(this._objectProgram);\n\t\tthis._context.setProgramConstantsFromArray(ContextGLProgramType.VERTEX, 4, this._viewportData, 1);\n\t\t//this.drawRenderables(entityCollector.opaqueRenderableHead, camera);\n\t\t//this.drawRenderables(entityCollector.blendedRenderableHead, camera);\n\t\t//TODO: reimplement ShaderPicker inheriting from RendererBase\n\t}\n\n\t/**\n\t * Draw a list of renderables.\n\t * @param renderables The renderables to draw.\n\t * @param camera The camera for which to render.\n\t */\n\tprivate drawRenderables(renderable:RenderableBase, camera:Camera)\n\t{\n\t\tvar matrix:Matrix3D = Matrix3DUtils.CALCULATION_MATRIX;\n\t\tvar viewProjection:Matrix3D = camera.viewProjection;\n\n\t\twhile (renderable) {\n\t\t\t// it's possible that the renderable was already removed from the scene\n\t\t\tif (!renderable.sourceEntity.scene || !renderable.sourceEntity._iIsMouseEnabled()) {\n\t\t\t\trenderable = renderable.next;\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tthis._potentialFound = true;\n\n\t\t\tthis._context.setCulling((<MaterialBase> renderable.materialOwner.material).bothSides? ContextGLTriangleFace.NONE : ContextGLTriangleFace.BACK, camera.projection.coordinateSystem);\n\n\t\t\tthis._interactives[this._interactiveId++] = renderable;\n\t\t\t// color code so that reading from bitmapdata will contain the correct value\n\t\t\tthis._id[1] = (this._interactiveId >> 8)/255; // on green channel\n\t\t\tthis._id[2] = (this._interactiveId & 0xff)/255; // on blue channel\n\n\t\t\tmatrix.copyFrom(renderable.sourceEntity.getRenderSceneTransform(camera));\n\t\t\tmatrix.append(viewProjection);\n\t\t\tthis._context.setProgramConstantsFromMatrix(ContextGLProgramType.VERTEX, 0, matrix, true);\n\t\t\tthis._context.setProgramConstantsFromArray(ContextGLProgramType.FRAGMENT, 0, this._id, 1);\n\t\t\tthis._context.activateBuffer(0, renderable.getVertexData(TriangleSubGeometry.POSITION_DATA), renderable.getVertexOffset(TriangleSubGeometry.POSITION_DATA), TriangleSubGeometry.POSITION_FORMAT);\n\t\t\tthis._context.drawTriangles(this._context.getIndexBuffer(renderable.getIndexData()), 0, renderable.numTriangles);\n\n\t\t\trenderable = renderable.next;\n\t\t}\n\n\t}\n\n\tprivate updateRay(camera:Camera)\n\t{\n\t\tthis._rayPos = camera.scenePosition;\n\n\t\tthis._rayDir = camera.getRay(this._projX, this._projY, 1);\n\t\tthis._rayDir.normalize();\n\t}\n\n\t/**\n\t * Creates the Program that color-codes objects.\n\t */\n\tprivate initObjectProgram()\n\t{\n\t\tvar vertexCode:string;\n\t\tvar fragmentCode:string;\n\n\t\tthis._objectProgram = this._context.createProgram();\n\n\t\tvertexCode = \"m44 vt0, va0, vc0\t\t\t\\n\" + \"mul vt1.xy, vt0.w, vc4.zw\t\\n\" + \"add vt0.xy, vt0.xy, vt1.xy\t\\n\" + \"mul vt0.xy, vt0.xy, vc4.xy\t\\n\" + \"mov op, vt0\t\\n\";\n\t\tfragmentCode = \"mov oc, fc0\"; // write identifier\n\n\t\tDebug.throwPIR('ShaderPicker', 'initTriangleProgram', 'Dependency: initObjectProgram')\n\t\t//_objectProgram.upload(new AGALMiniAssembler().assemble(ContextGLProgramType.VERTEX, vertexCode),new AGALMiniAssembler().assemble(ContextGLProgramType.FRAGMENT, fragmentCode));\n\t}\n\n\t/**\n\t * Creates the Program that renders positions.\n\t */\n\n\tprivate initTriangleProgram()\n\t{\n\t\tvar vertexCode:string;\n\t\tvar fragmentCode:string;\n\n\t\tthis._triangleProgram = this._context.createProgram();\n\n\t\t// todo: add animation code\n\t\tvertexCode = \"add vt0, va0, vc5 \t\t\t\\n\" + \"mul vt0, vt0, vc6 \t\t\t\\n\" + \"mov v0, vt0\t\t\t\t\\n\" + \"m44 vt0, va0, vc0\t\t\t\\n\" + \"mul vt1.xy, vt0.w, vc4.zw\t\\n\" + \"add vt0.xy, vt0.xy, vt1.xy\t\\n\" + \"mul vt0.xy, vt0.xy, vc4.xy\t\\n\" + \"mov op, vt0\t\\n\";\n\t\tfragmentCode = \"mov oc, v0\"; // write identifier\n\n\t\tvar vertexByteCode:ByteArray = (new AGALMiniAssembler().assemble(\"part vertex 1\\n\" + vertexCode + \"endpart\"))['vertex'].data;\n\t\tvar fragmentByteCode:ByteArray = (new AGALMiniAssembler().assemble(\"part fragment 1\\n\" + fragmentCode + \"endpart\"))['fragment'].data;\n\t\tthis._triangleProgram.upload(vertexByteCode, fragmentByteCode);\n\t}\n\n\t/**\n\t * Gets more detailed information about the hir position, if required.\n\t * @param camera The camera used to view the hit object.\n\t */\n\tprivate getHitDetails(camera:Camera)\n\t{\n\t\tthis.getApproximatePosition(camera);\n\t\tthis.getPreciseDetails(camera);\n\t}\n\n\t/**\n\t * Finds a first-guess approximate position about the hit position.\n\t *\n\t * @param camera The camera used to view the hit object.\n\t */\n\tprivate getApproximatePosition(camera:Camera)\n\t{\n\t\tvar bounds:Box = this._hitRenderable.sourceEntity.bounds.aabb;\n\t\tvar col:number;\n\t\tvar scX:number, scY:number, scZ:number;\n\t\tvar offsX:number, offsY:number, offsZ:number;\n\t\tvar localViewProjection:Matrix3D = Matrix3DUtils.CALCULATION_MATRIX;\n\n\t\tlocalViewProjection.copyFrom(this._hitRenderable.sourceEntity.getRenderSceneTransform(camera));\n\t\tlocalViewProjection.append(camera.viewProjection);\n\t\tif (!this._triangleProgram) {\n\t\t\tthis.initTriangleProgram();\n\t\t}\n\n\t\tthis._boundOffsetScale[4] = 1/(scX = bounds.width);\n\t\tthis._boundOffsetScale[5] = 1/(scY = bounds.height);\n\t\tthis._boundOffsetScale[6] = 1/(scZ = bounds.depth);\n\t\tthis._boundOffsetScale[0] = offsX = -bounds.x;\n\t\tthis._boundOffsetScale[1] = offsY = -bounds.y;\n\t\tthis._boundOffsetScale[2] = offsZ = -bounds.z;\n\n\t\tthis._context.setProgram(this._triangleProgram);\n\t\tthis._context.clear(0, 0, 0, 0, 1, 0, ContextGLClearMask.DEPTH);\n\t\tthis._context.setScissorRectangle(ShaderPicker.MOUSE_SCISSOR_RECT);\n\t\tthis._context.setProgramConstantsFromMatrix(ContextGLProgramType.VERTEX, 0, localViewProjection, true);\n\t\tthis._context.setProgramConstantsFromArray(ContextGLProgramType.VERTEX, 5, this._boundOffsetScale, 2);\n\n\t\tthis._context.activateBuffer(0, this._hitRenderable.getVertexData(TriangleSubGeometry.POSITION_DATA), this._hitRenderable.getVertexOffset(TriangleSubGeometry.POSITION_DATA), TriangleSubGeometry.POSITION_FORMAT);\n\t\tthis._context.drawTriangles(this._context.getIndexBuffer(this._hitRenderable.getIndexData()), 0, this._hitRenderable.numTriangles);\n\n\t\tthis._context.drawToBitmapData(this._bitmapData);\n\n\t\tcol = this._bitmapData.getPixel(0, 0);\n\n\t\tthis._localHitPosition.x = ((col >> 16) & 0xff)*scX/255 - offsX;\n\t\tthis._localHitPosition.y = ((col >> 8) & 0xff)*scY/255 - offsY;\n\t\tthis._localHitPosition.z = (col & 0xff)*scZ/255 - offsZ;\n\t}\n\n\t/**\n\t * Use the approximate position info to find the face under the mouse position from which we can derive the precise\n\t * ray-face intersection point, then use barycentric coordinates to figure out the uv coordinates, etc.\n\t * @param camera The camera used to view the hit object.\n\t */\n\tprivate getPreciseDetails(camera:Camera)\n\t{\n\t\tvar len:number = indices.length;\n\t\tvar x1:number, y1:number, z1:number;\n\t\tvar x2:number, y2:number, z2:number;\n\t\tvar x3:number, y3:number, z3:number;\n\t\tvar i:number = 0, j:number = 1, k:number = 2;\n\t\tvar t1:number, t2:number, t3:number;\n\t\tvar v0x:number, v0y:number, v0z:number;\n\t\tvar v1x:number, v1y:number, v1z:number;\n\t\tvar v2x:number, v2y:number, v2z:number;\n\t\tvar ni1:number, ni2:number, ni3:number;\n\t\tvar n1:number, n2:number, n3:number, nLength:number;\n\t\tvar dot00:number, dot01:number, dot02:number, dot11:number, dot12:number;\n\t\tvar s:number, t:number, invDenom:number;\n\t\tvar x:number = this._localHitPosition.x, y:number = this._localHitPosition.y, z:number = this._localHitPosition.z;\n\t\tvar u:number, v:number;\n\t\tvar ui1:number, ui2:number, ui3:number;\n\t\tvar s0x:number, s0y:number, s0z:number;\n\t\tvar s1x:number, s1y:number, s1z:number;\n\t\tvar nl:number;\n\t\tvar indices:Array<number> = this._hitRenderable.getIndexData().data;\n\n\t\tvar positions:Array<number> = this._hitRenderable.getVertexData(TriangleSubGeometry.POSITION_DATA).data;\n\t\tvar positionStride:number = this._hitRenderable.getVertexData(TriangleSubGeometry.POSITION_DATA).dataPerVertex;\n\t\tvar positionOffset:number = this._hitRenderable.getVertexOffset(TriangleSubGeometry.POSITION_DATA);\n\n\t\tvar uvs:Array<number> = this._hitRenderable.getVertexData(TriangleSubGeometry.UV_DATA).data;\n\t\tvar uvStride:number = this._hitRenderable.getVertexData(TriangleSubGeometry.UV_DATA).dataPerVertex;\n\t\tvar uvOffset:number = this._hitRenderable.getVertexOffset(TriangleSubGeometry.UV_DATA);\n\n\t\tvar normals:Array<number> = this._hitRenderable.getVertexData(TriangleSubGeometry.NORMAL_DATA).data;\n\t\tvar normalStride:number = this._hitRenderable.getVertexData(TriangleSubGeometry.NORMAL_DATA).dataPerVertex;\n\t\tvar normalOffset:number = this._hitRenderable.getVertexOffset(TriangleSubGeometry.NORMAL_DATA);\n\n\t\tthis.updateRay(camera);\n\n\t\twhile (i < len) {\n\t\t\tt1 = positionOffset + indices[i]*positionStride;\n\t\t\tt2 = positionOffset + indices[j]*positionStride;\n\t\t\tt3 = positionOffset + indices[k]*positionStride;\n\t\t\tx1 = positions[t1];\n\t\t\ty1 = positions[t1 + 1];\n\t\t\tz1 = positions[t1 + 2];\n\t\t\tx2 = positions[t2];\n\t\t\ty2 = positions[t2 + 1];\n\t\t\tz2 = positions[t2 + 2];\n\t\t\tx3 = positions[t3];\n\t\t\ty3 = positions[t3 + 1];\n\t\t\tz3 = positions[t3 + 2];\n\n\t\t\t// if within bounds\n\t\t\tif (!(    (x < x1 && x < x2 && x < x3) || (y < y1 && y < y2 && y < y3) || (z < z1 && z < z2 && z < z3) || (x > x1 && x > x2 && x > x3) || (y > y1 && y > y2 && y > y3) || (z > z1 && z > z2 && z > z3))) {\n\n\t\t\t\t// calculate barycentric coords for approximated position\n\t\t\t\tv0x = x3 - x1;\n\t\t\t\tv0y = y3 - y1;\n\t\t\t\tv0z = z3 - z1;\n\t\t\t\tv1x = x2 - x1;\n\t\t\t\tv1y = y2 - y1;\n\t\t\t\tv1z = z2 - z1;\n\t\t\t\tv2x = x - x1;\n\t\t\t\tv2y = y - y1;\n\t\t\t\tv2z = z - z1;\n\t\t\t\tdot00 = v0x*v0x + v0y*v0y + v0z*v0z;\n\t\t\t\tdot01 = v0x*v1x + v0y*v1y + v0z*v1z;\n\t\t\t\tdot02 = v0x*v2x + v0y*v2y + v0z*v2z;\n\t\t\t\tdot11 = v1x*v1x + v1y*v1y + v1z*v1z;\n\t\t\t\tdot12 = v1x*v2x + v1y*v2y + v1z*v2z;\n\t\t\t\tinvDenom = 1/(dot00*dot11 - dot01*dot01);\n\t\t\t\ts = (dot11*dot02 - dot01*dot12)*invDenom;\n\t\t\t\tt = (dot00*dot12 - dot01*dot02)*invDenom;\n\n\t\t\t\t// if inside the current triangle, fetch details hit information\n\t\t\t\tif (s >= 0 && t >= 0 && (s + t) <= 1) {\n\n\t\t\t\t\tni1 = normalOffset + indices[i]*normalStride;\n\t\t\t\t\tni2 = normalOffset + indices[j]*normalStride;\n\t\t\t\t\tni3 = normalOffset + indices[k]*normalStride;\n\n\t\t\t\t\tn1 = indices[ni1] + indices[ni2] + indices[ni3];\n\t\t\t\t\tn2 = indices[ni1 + 1] + indices[ni2 + 1] + indices[ni3 + 1];\n\t\t\t\t\tn3 = indices[ni1 + 2] + indices[ni2 + 2] + indices[ni3 + 2];\n\n\t\t\t\t\tnLength = Math.sqrt(n1*n1 + n2*n2 + n3*n3);\n\n\t\t\t\t\tn1 /= nLength;\n\t\t\t\t\tn2 /= nLength;\n\t\t\t\t\tn3 /= nLength;\n\n\t\t\t\t\t// this is def the triangle, now calculate precise coords\n\t\t\t\t\tthis.getPrecisePosition(this._hitRenderable.sourceEntity.inverseSceneTransform, n1, n2, n3, x1, y1, z1);\n\n\t\t\t\t\tv2x = this._localHitPosition.x - x1;\n\t\t\t\t\tv2y = this._localHitPosition.y - y1;\n\t\t\t\t\tv2z = this._localHitPosition.z - z1;\n\n\t\t\t\t\ts0x = x2 - x1; // s0 = p1 - p0\n\t\t\t\t\ts0y = y2 - y1;\n\t\t\t\t\ts0z = z2 - z1;\n\t\t\t\t\ts1x = x3 - x1; // s1 = p2 - p0\n\t\t\t\t\ts1y = y3 - y1;\n\t\t\t\t\ts1z = z3 - z1;\n\t\t\t\t\tthis._localHitNormal.x = s0y*s1z - s0z*s1y; // n = s0 x s1\n\t\t\t\t\tthis._localHitNormal.y = s0z*s1x - s0x*s1z;\n\t\t\t\t\tthis._localHitNormal.z = s0x*s1y - s0y*s1x;\n\t\t\t\t\tnl = 1/Math.sqrt(this._localHitNormal.x*this._localHitNormal.x + this._localHitNormal.y*this._localHitNormal.y + this._localHitNormal.z*this._localHitNormal.z); // normalize n\n\t\t\t\t\tthis._localHitNormal.x *= nl;\n\t\t\t\t\tthis._localHitNormal.y *= nl;\n\t\t\t\t\tthis._localHitNormal.z *= nl;\n\n\t\t\t\t\tdot02 = v0x*v2x + v0y*v2y + v0z*v2z;\n\t\t\t\t\tdot12 = v1x*v2x + v1y*v2y + v1z*v2z;\n\t\t\t\t\ts = (dot11*dot02 - dot01*dot12)*invDenom;\n\t\t\t\t\tt = (dot00*dot12 - dot01*dot02)*invDenom;\n\n\t\t\t\t\tui1 = uvOffset + indices[i]*uvStride\n\t\t\t\t\tui2 = uvOffset + indices[j]*uvStride\n\t\t\t\t\tui3 = uvOffset + indices[k]*uvStride\n\n\t\t\t\t\tu = uvs[ui1];\n\t\t\t\t\tv = uvs[ui1 + 1];\n\t\t\t\t\tthis._hitUV.x = u + t*(uvs[ui2] - u) + s*(uvs[ui3] - u);\n\t\t\t\t\tthis._hitUV.y = v + t*(uvs[ui2 + 1] - v) + s*(uvs[ui3 + 1] - v);\n\n\t\t\t\t\tthis._faceIndex = i;\n\t\t\t\t\t//TODO add back subGeometryIndex value\n\t\t\t\t\t//this._subGeometryIndex = away.utils.GeometryUtils.getMeshSubGeometryIndex(subGeom);\n\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\ti += 3;\n\t\t\tj += 3;\n\t\t\tk += 3;\n\t\t}\n\t}\n\n\t/**\n\t * Finds the precise hit position by unprojecting the screen coordinate back unto the hit face's plane and\n\t * calculating the intersection point.\n\t * @param camera The camera used to render the object.\n\t * @param invSceneTransform The inverse scene transformation of the hit object.\n\t * @param nx The x-coordinate of the face's plane normal.\n\t * @param ny The y-coordinate of the face plane normal.\n\t * @param nz The z-coordinate of the face plane normal.\n\t * @param px The x-coordinate of a point on the face's plane (ie a face vertex)\n\t * @param py The y-coordinate of a point on the face's plane (ie a face vertex)\n\t * @param pz The z-coordinate of a point on the face's plane (ie a face vertex)\n\t */\n\n\tprivate getPrecisePosition(invSceneTransform:Matrix3D, nx:number, ny:number, nz:number, px:number, py:number, pz:number)\n\t{\n\t\t// calculate screen ray and find exact intersection position with triangle\n\t\tvar rx:number, ry:number, rz:number;\n\t\tvar ox:number, oy:number, oz:number;\n\t\tvar t:number;\n\t\tvar raw:Array<number> = Matrix3DUtils.RAW_DATA_CONTAINER;\n\t\tvar cx:number = this._rayPos.x, cy:number = this._rayPos.y, cz:number = this._rayPos.z;\n\n\t\t// unprojected projection point, gives ray dir in cam space\n\t\tox = this._rayDir.x;\n\t\toy = this._rayDir.y;\n\t\toz = this._rayDir.z;\n\n\t\t// transform ray dir and origin (cam pos) to object space\n\t\t//invSceneTransform.copyRawDataTo( raw  );\n\t\tinvSceneTransform.copyRawDataTo(raw);\n\t\trx = raw[0]*ox + raw[4]*oy + raw[8]*oz;\n\t\try = raw[1]*ox + raw[5]*oy + raw[9]*oz;\n\t\trz = raw[2]*ox + raw[6]*oy + raw[10]*oz;\n\n\t\tox = raw[0]*cx + raw[4]*cy + raw[8]*cz + raw[12];\n\t\toy = raw[1]*cx + raw[5]*cy + raw[9]*cz + raw[13];\n\t\toz = raw[2]*cx + raw[6]*cy + raw[10]*cz + raw[14];\n\n\t\tt = ((px - ox)*nx + (py - oy)*ny + (pz - oz)*nz)/(rx*nx + ry*ny + rz*nz);\n\n\t\tthis._localHitPosition.x = ox + rx*t;\n\t\tthis._localHitPosition.y = oy + ry*t;\n\t\tthis._localHitPosition.z = oz + rz*t;\n\t}\n\n\tpublic dispose()\n\t{\n\t\tthis._bitmapData.dispose();\n\t\tif (this._triangleProgram)\n\t\t\tthis._triangleProgram.dispose();\n\n\t\tif (this._objectProgram)\n\t\t\tthis._objectProgram.dispose();\n\n\t\tthis._triangleProgram = null;\n\t\tthis._objectProgram = null;\n\t\tthis._bitmapData = null;\n\t\tthis._hitRenderable = null;\n\t\tthis._hitEntity = null;\n\t}\n}\n\nexport = ShaderPicker;"]}
\ No newline at end of file
diff --git a/lib/core/pick/ShaderPicker.ts b/lib/core/pick/ShaderPicker.ts
new file mode 100644
index 000000000..b480e38ff
--- /dev/null
+++ b/lib/core/pick/ShaderPicker.ts
@@ -0,0 +1,560 @@
+import Debug = require("awayjs-core/lib/utils/Debug");
+import BitmapData = require("awayjs-core/lib/core/base/BitmapData");
+import TriangleSubGeometry = require("awayjs-core/lib/core/base/TriangleSubGeometry");
+import Scene = require("awayjs-core/lib/containers/Scene");
+import View = require("awayjs-core/lib/containers/View");
+import Box = require("awayjs-core/lib/core/geom/Box");
+import Matrix3D = require("awayjs-core/lib/core/geom/Matrix3D");
+import Matrix3DUtils = require("awayjs-core/lib/core/geom/Matrix3DUtils");
+import Point = require("awayjs-core/lib/core/geom/Point");
+import Rectangle = require("awayjs-core/lib/core/geom/Rectangle");
+import Vector3D = require("awayjs-core/lib/core/geom/Vector3D");
+import IPicker = require("awayjs-core/lib/core/pick/IPicker");
+import PickingCollisionVO = require("awayjs-core/lib/core/pick/PickingCollisionVO");
+import EntityCollector = require("awayjs-core/lib/core/traverse/EntityCollector");
+import Camera = require("awayjs-core/lib/entities/Camera");
+import IEntity = require("awayjs-core/lib/entities/IEntity");
+import MaterialBase = require("awayjs-core/lib/materials/MaterialBase");
+import ByteArray = require("awayjs-core/lib/utils/ByteArray");
+
+import AGALMiniAssembler = require("awayjs-stagegl/lib/aglsl/assembler/AGALMiniAssembler");
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import DefaultRenderer = require("awayjs-stagegl/lib/core/render/DefaultRenderer");
+import ContextGLBlendFactor = require("awayjs-stagegl/lib/core/stagegl/ContextGLBlendFactor");
+import ContextGLClearMask = require("awayjs-stagegl/lib/core/stagegl/ContextGLClearMask");
+import ContextGLCompareMode = require("awayjs-stagegl/lib/core/stagegl/ContextGLCompareMode");
+import ContextGLProgramType = require("awayjs-stagegl/lib/core/stagegl/ContextGLProgramType");
+import ContextGLTriangleFace = require("awayjs-stagegl/lib/core/stagegl/ContextGLTriangleFace");
+import IContextStageGL = require("awayjs-stagegl/lib/core/stagegl/IContextStageGL");
+import IProgram = require("awayjs-stagegl/lib/core/stagegl/IProgram");
+import ITextureBase = require("awayjs-stagegl/lib/core/stagegl/ITextureBase");
+
+/**
+ * Picks a 3d object from a view or scene by performing a separate render pass on the scene around the area being picked using key color values,
+ * then reading back the color value of the pixel in the render representing the picking ray. Requires multiple passes and readbacks for retriving details
+ * on an entity that has its shaderPickingDetails property set to true.
+ *
+ * A read-back operation from any GPU is not a very efficient process, and the amount of processing used can vary significantly between different hardware.
+ *
+ * @see away.entities.Entity#shaderPickingDetails
+ *
+ * @class away.pick.ShaderPicker
+ */
+class ShaderPicker implements IPicker
+{
+ private _opaqueRenderableHead:RenderableBase;
+ private _blendedRenderableHead:RenderableBase;
+
+ private _stage:Stage;
+ private _context:IContextStageGL;
+ private _onlyMouseEnabled:boolean = true;
+
+ private _objectProgram:IProgram;
+ private _triangleProgram:IProgram;
+ private _bitmapData:BitmapData;
+ private _viewportData:Array;
+ private _boundOffsetScale:Array;
+ private _id:Array;
+
+ private _interactives:Array = new Array();
+ private _interactiveId:number;
+ private _hitColor:number;
+ private _projX:number;
+ private _projY:number;
+
+ private _hitRenderable:RenderableBase;
+ private _hitEntity:IEntity;
+ private _localHitPosition:Vector3D = new Vector3D();
+ private _hitUV:Point = new Point();
+ private _faceIndex:number;
+ private _subGeometryIndex:number;
+
+ private _localHitNormal:Vector3D = new Vector3D();
+
+ private _rayPos:Vector3D = new Vector3D();
+ private _rayDir:Vector3D = new Vector3D();
+ private _potentialFound:boolean;
+ private static MOUSE_SCISSOR_RECT:Rectangle = new Rectangle(0, 0, 1, 1);
+
+ private _shaderPickingDetails:boolean;
+
+ /**
+ * @inheritDoc
+ */
+ public get onlyMouseEnabled():boolean
+ {
+ return this._onlyMouseEnabled;
+ }
+
+ public set onlyMouseEnabled(value:boolean)
+ {
+ this._onlyMouseEnabled = value;
+ }
+
+ /**
+ * Creates a new ShaderPicker
object.
+ *
+ * @param shaderPickingDetails Determines whether the picker includes a second pass to calculate extra
+ * properties such as uv and normal coordinates.
+ */
+ constructor(shaderPickingDetails:boolean = false)
+ {
+ this._shaderPickingDetails = shaderPickingDetails;
+
+ this._id = new Array(4);
+ this._viewportData = new Array(4); // first 2 contain scale, last 2 translation
+ this._boundOffsetScale = new Array(8); // first 2 contain scale, last 2 translation
+ this._boundOffsetScale[3] = 0;
+ this._boundOffsetScale[7] = 1;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public getViewCollision(x:number, y:number, view:View):PickingCollisionVO
+ {
+ var collector:EntityCollector = view.iEntityCollector;
+
+ this._stage = ( view.renderer).stage;
+
+ if (!this._stage)
+ return null;
+
+ this._context = this._stage.context;
+
+ this._viewportData[0] = view.width;
+ this._viewportData[1] = view.height;
+ this._viewportData[2] = -(this._projX = 2*x/view.width - 1);
+ this._viewportData[3] = this._projY = 2*y/view.height - 1;
+
+ // _potentialFound will be set to true if any object is actually rendered
+ this._potentialFound = false;
+
+ //reset head values
+ this._blendedRenderableHead = null;
+ this._opaqueRenderableHead = null;
+
+ this.pDraw(collector, null);
+
+ // clear buffers
+ this._context.setVertexBufferAt(0, null);
+
+ if (!this._context || !this._potentialFound)
+ return null;
+
+ if (!this._bitmapData)
+ this._bitmapData = new BitmapData(1, 1, false, 0);
+
+ this._context.drawToBitmapData(this._bitmapData);
+ this._hitColor = this._bitmapData.getPixel(0, 0);
+
+ if (!this._hitColor) {
+ this._context.present();
+ return null;
+ }
+
+ this._hitRenderable = this._interactives[this._hitColor - 1];
+ this._hitEntity = this._hitRenderable.sourceEntity;
+
+ if (this._onlyMouseEnabled && !this._hitEntity._iIsMouseEnabled())
+ return null;
+
+ var _collisionVO:PickingCollisionVO = this._hitEntity._iPickingCollisionVO;
+ if (this._shaderPickingDetails) {
+ this.getHitDetails(view.camera);
+ _collisionVO.localPosition = this._localHitPosition;
+ _collisionVO.localNormal = this._localHitNormal;
+ _collisionVO.uv = this._hitUV;
+ _collisionVO.index = this._faceIndex;
+ //_collisionVO.subGeometryIndex = this._subGeometryIndex;
+
+ } else {
+ _collisionVO.localPosition = null;
+ _collisionVO.localNormal = null;
+ _collisionVO.uv = null;
+ _collisionVO.index = 0;
+ //_collisionVO.subGeometryIndex = 0;
+ }
+
+ return _collisionVO;
+ }
+
+ //*/
+ /**
+ * @inheritDoc
+ */
+ public getSceneCollision(position:Vector3D, direction:Vector3D, scene:Scene):PickingCollisionVO
+ {
+ return null;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public pDraw(entityCollector:EntityCollector, target:ITextureBase)
+ {
+
+ var camera:Camera = entityCollector.camera;
+
+ this._context.clear(0, 0, 0, 1);
+ this._stage.scissorRect = ShaderPicker.MOUSE_SCISSOR_RECT;
+
+ this._interactives.length = this._interactiveId = 0;
+
+ if (!this._objectProgram)
+ this.initObjectProgram();
+
+ this._context.setBlendFactors(ContextGLBlendFactor.ONE, ContextGLBlendFactor.ZERO);
+ this._context.setDepthTest(true, ContextGLCompareMode.LESS);
+ this._context.setProgram(this._objectProgram);
+ this._context.setProgramConstantsFromArray(ContextGLProgramType.VERTEX, 4, this._viewportData, 1);
+ //this.drawRenderables(entityCollector.opaqueRenderableHead, camera);
+ //this.drawRenderables(entityCollector.blendedRenderableHead, camera);
+ //TODO: reimplement ShaderPicker inheriting from RendererBase
+ }
+
+ /**
+ * Draw a list of renderables.
+ * @param renderables The renderables to draw.
+ * @param camera The camera for which to render.
+ */
+ private drawRenderables(renderable:RenderableBase, camera:Camera)
+ {
+ var matrix:Matrix3D = Matrix3DUtils.CALCULATION_MATRIX;
+ var viewProjection:Matrix3D = camera.viewProjection;
+
+ while (renderable) {
+ // it's possible that the renderable was already removed from the scene
+ if (!renderable.sourceEntity.scene || !renderable.sourceEntity._iIsMouseEnabled()) {
+ renderable = renderable.next;
+ continue;
+ }
+
+ this._potentialFound = true;
+
+ this._context.setCulling(( renderable.materialOwner.material).bothSides? ContextGLTriangleFace.NONE : ContextGLTriangleFace.BACK, camera.projection.coordinateSystem);
+
+ this._interactives[this._interactiveId++] = renderable;
+ // color code so that reading from bitmapdata will contain the correct value
+ this._id[1] = (this._interactiveId >> 8)/255; // on green channel
+ this._id[2] = (this._interactiveId & 0xff)/255; // on blue channel
+
+ matrix.copyFrom(renderable.sourceEntity.getRenderSceneTransform(camera));
+ matrix.append(viewProjection);
+ this._context.setProgramConstantsFromMatrix(ContextGLProgramType.VERTEX, 0, matrix, true);
+ this._context.setProgramConstantsFromArray(ContextGLProgramType.FRAGMENT, 0, this._id, 1);
+ this._context.activateBuffer(0, renderable.getVertexData(TriangleSubGeometry.POSITION_DATA), renderable.getVertexOffset(TriangleSubGeometry.POSITION_DATA), TriangleSubGeometry.POSITION_FORMAT);
+ this._context.drawTriangles(this._context.getIndexBuffer(renderable.getIndexData()), 0, renderable.numTriangles);
+
+ renderable = renderable.next;
+ }
+
+ }
+
+ private updateRay(camera:Camera)
+ {
+ this._rayPos = camera.scenePosition;
+
+ this._rayDir = camera.getRay(this._projX, this._projY, 1);
+ this._rayDir.normalize();
+ }
+
+ /**
+ * Creates the Program that color-codes objects.
+ */
+ private initObjectProgram()
+ {
+ var vertexCode:string;
+ var fragmentCode:string;
+
+ this._objectProgram = this._context.createProgram();
+
+ vertexCode = "m44 vt0, va0, vc0 \n" + "mul vt1.xy, vt0.w, vc4.zw \n" + "add vt0.xy, vt0.xy, vt1.xy \n" + "mul vt0.xy, vt0.xy, vc4.xy \n" + "mov op, vt0 \n";
+ fragmentCode = "mov oc, fc0"; // write identifier
+
+ Debug.throwPIR('ShaderPicker', 'initTriangleProgram', 'Dependency: initObjectProgram')
+ //_objectProgram.upload(new AGALMiniAssembler().assemble(ContextGLProgramType.VERTEX, vertexCode),new AGALMiniAssembler().assemble(ContextGLProgramType.FRAGMENT, fragmentCode));
+ }
+
+ /**
+ * Creates the Program that renders positions.
+ */
+
+ private initTriangleProgram()
+ {
+ var vertexCode:string;
+ var fragmentCode:string;
+
+ this._triangleProgram = this._context.createProgram();
+
+ // todo: add animation code
+ vertexCode = "add vt0, va0, vc5 \n" + "mul vt0, vt0, vc6 \n" + "mov v0, vt0 \n" + "m44 vt0, va0, vc0 \n" + "mul vt1.xy, vt0.w, vc4.zw \n" + "add vt0.xy, vt0.xy, vt1.xy \n" + "mul vt0.xy, vt0.xy, vc4.xy \n" + "mov op, vt0 \n";
+ fragmentCode = "mov oc, v0"; // write identifier
+
+ var vertexByteCode:ByteArray = (new AGALMiniAssembler().assemble("part vertex 1\n" + vertexCode + "endpart"))['vertex'].data;
+ var fragmentByteCode:ByteArray = (new AGALMiniAssembler().assemble("part fragment 1\n" + fragmentCode + "endpart"))['fragment'].data;
+ this._triangleProgram.upload(vertexByteCode, fragmentByteCode);
+ }
+
+ /**
+ * Gets more detailed information about the hir position, if required.
+ * @param camera The camera used to view the hit object.
+ */
+ private getHitDetails(camera:Camera)
+ {
+ this.getApproximatePosition(camera);
+ this.getPreciseDetails(camera);
+ }
+
+ /**
+ * Finds a first-guess approximate position about the hit position.
+ *
+ * @param camera The camera used to view the hit object.
+ */
+ private getApproximatePosition(camera:Camera)
+ {
+ var bounds:Box = this._hitRenderable.sourceEntity.bounds.aabb;
+ var col:number;
+ var scX:number, scY:number, scZ:number;
+ var offsX:number, offsY:number, offsZ:number;
+ var localViewProjection:Matrix3D = Matrix3DUtils.CALCULATION_MATRIX;
+
+ localViewProjection.copyFrom(this._hitRenderable.sourceEntity.getRenderSceneTransform(camera));
+ localViewProjection.append(camera.viewProjection);
+ if (!this._triangleProgram) {
+ this.initTriangleProgram();
+ }
+
+ this._boundOffsetScale[4] = 1/(scX = bounds.width);
+ this._boundOffsetScale[5] = 1/(scY = bounds.height);
+ this._boundOffsetScale[6] = 1/(scZ = bounds.depth);
+ this._boundOffsetScale[0] = offsX = -bounds.x;
+ this._boundOffsetScale[1] = offsY = -bounds.y;
+ this._boundOffsetScale[2] = offsZ = -bounds.z;
+
+ this._context.setProgram(this._triangleProgram);
+ this._context.clear(0, 0, 0, 0, 1, 0, ContextGLClearMask.DEPTH);
+ this._context.setScissorRectangle(ShaderPicker.MOUSE_SCISSOR_RECT);
+ this._context.setProgramConstantsFromMatrix(ContextGLProgramType.VERTEX, 0, localViewProjection, true);
+ this._context.setProgramConstantsFromArray(ContextGLProgramType.VERTEX, 5, this._boundOffsetScale, 2);
+
+ this._context.activateBuffer(0, this._hitRenderable.getVertexData(TriangleSubGeometry.POSITION_DATA), this._hitRenderable.getVertexOffset(TriangleSubGeometry.POSITION_DATA), TriangleSubGeometry.POSITION_FORMAT);
+ this._context.drawTriangles(this._context.getIndexBuffer(this._hitRenderable.getIndexData()), 0, this._hitRenderable.numTriangles);
+
+ this._context.drawToBitmapData(this._bitmapData);
+
+ col = this._bitmapData.getPixel(0, 0);
+
+ this._localHitPosition.x = ((col >> 16) & 0xff)*scX/255 - offsX;
+ this._localHitPosition.y = ((col >> 8) & 0xff)*scY/255 - offsY;
+ this._localHitPosition.z = (col & 0xff)*scZ/255 - offsZ;
+ }
+
+ /**
+ * Use the approximate position info to find the face under the mouse position from which we can derive the precise
+ * ray-face intersection point, then use barycentric coordinates to figure out the uv coordinates, etc.
+ * @param camera The camera used to view the hit object.
+ */
+ private getPreciseDetails(camera:Camera)
+ {
+ var len:number = indices.length;
+ var x1:number, y1:number, z1:number;
+ var x2:number, y2:number, z2:number;
+ var x3:number, y3:number, z3:number;
+ var i:number = 0, j:number = 1, k:number = 2;
+ var t1:number, t2:number, t3:number;
+ var v0x:number, v0y:number, v0z:number;
+ var v1x:number, v1y:number, v1z:number;
+ var v2x:number, v2y:number, v2z:number;
+ var ni1:number, ni2:number, ni3:number;
+ var n1:number, n2:number, n3:number, nLength:number;
+ var dot00:number, dot01:number, dot02:number, dot11:number, dot12:number;
+ var s:number, t:number, invDenom:number;
+ var x:number = this._localHitPosition.x, y:number = this._localHitPosition.y, z:number = this._localHitPosition.z;
+ var u:number, v:number;
+ var ui1:number, ui2:number, ui3:number;
+ var s0x:number, s0y:number, s0z:number;
+ var s1x:number, s1y:number, s1z:number;
+ var nl:number;
+ var indices:Array = this._hitRenderable.getIndexData().data;
+
+ var positions:Array = this._hitRenderable.getVertexData(TriangleSubGeometry.POSITION_DATA).data;
+ var positionStride:number = this._hitRenderable.getVertexData(TriangleSubGeometry.POSITION_DATA).dataPerVertex;
+ var positionOffset:number = this._hitRenderable.getVertexOffset(TriangleSubGeometry.POSITION_DATA);
+
+ var uvs:Array = this._hitRenderable.getVertexData(TriangleSubGeometry.UV_DATA).data;
+ var uvStride:number = this._hitRenderable.getVertexData(TriangleSubGeometry.UV_DATA).dataPerVertex;
+ var uvOffset:number = this._hitRenderable.getVertexOffset(TriangleSubGeometry.UV_DATA);
+
+ var normals:Array = this._hitRenderable.getVertexData(TriangleSubGeometry.NORMAL_DATA).data;
+ var normalStride:number = this._hitRenderable.getVertexData(TriangleSubGeometry.NORMAL_DATA).dataPerVertex;
+ var normalOffset:number = this._hitRenderable.getVertexOffset(TriangleSubGeometry.NORMAL_DATA);
+
+ this.updateRay(camera);
+
+ while (i < len) {
+ t1 = positionOffset + indices[i]*positionStride;
+ t2 = positionOffset + indices[j]*positionStride;
+ t3 = positionOffset + indices[k]*positionStride;
+ x1 = positions[t1];
+ y1 = positions[t1 + 1];
+ z1 = positions[t1 + 2];
+ x2 = positions[t2];
+ y2 = positions[t2 + 1];
+ z2 = positions[t2 + 2];
+ x3 = positions[t3];
+ y3 = positions[t3 + 1];
+ z3 = positions[t3 + 2];
+
+ // if within bounds
+ if (!( (x < x1 && x < x2 && x < x3) || (y < y1 && y < y2 && y < y3) || (z < z1 && z < z2 && z < z3) || (x > x1 && x > x2 && x > x3) || (y > y1 && y > y2 && y > y3) || (z > z1 && z > z2 && z > z3))) {
+
+ // calculate barycentric coords for approximated position
+ v0x = x3 - x1;
+ v0y = y3 - y1;
+ v0z = z3 - z1;
+ v1x = x2 - x1;
+ v1y = y2 - y1;
+ v1z = z2 - z1;
+ v2x = x - x1;
+ v2y = y - y1;
+ v2z = z - z1;
+ dot00 = v0x*v0x + v0y*v0y + v0z*v0z;
+ dot01 = v0x*v1x + v0y*v1y + v0z*v1z;
+ dot02 = v0x*v2x + v0y*v2y + v0z*v2z;
+ dot11 = v1x*v1x + v1y*v1y + v1z*v1z;
+ dot12 = v1x*v2x + v1y*v2y + v1z*v2z;
+ invDenom = 1/(dot00*dot11 - dot01*dot01);
+ s = (dot11*dot02 - dot01*dot12)*invDenom;
+ t = (dot00*dot12 - dot01*dot02)*invDenom;
+
+ // if inside the current triangle, fetch details hit information
+ if (s >= 0 && t >= 0 && (s + t) <= 1) {
+
+ ni1 = normalOffset + indices[i]*normalStride;
+ ni2 = normalOffset + indices[j]*normalStride;
+ ni3 = normalOffset + indices[k]*normalStride;
+
+ n1 = indices[ni1] + indices[ni2] + indices[ni3];
+ n2 = indices[ni1 + 1] + indices[ni2 + 1] + indices[ni3 + 1];
+ n3 = indices[ni1 + 2] + indices[ni2 + 2] + indices[ni3 + 2];
+
+ nLength = Math.sqrt(n1*n1 + n2*n2 + n3*n3);
+
+ n1 /= nLength;
+ n2 /= nLength;
+ n3 /= nLength;
+
+ // this is def the triangle, now calculate precise coords
+ this.getPrecisePosition(this._hitRenderable.sourceEntity.inverseSceneTransform, n1, n2, n3, x1, y1, z1);
+
+ v2x = this._localHitPosition.x - x1;
+ v2y = this._localHitPosition.y - y1;
+ v2z = this._localHitPosition.z - z1;
+
+ s0x = x2 - x1; // s0 = p1 - p0
+ s0y = y2 - y1;
+ s0z = z2 - z1;
+ s1x = x3 - x1; // s1 = p2 - p0
+ s1y = y3 - y1;
+ s1z = z3 - z1;
+ this._localHitNormal.x = s0y*s1z - s0z*s1y; // n = s0 x s1
+ this._localHitNormal.y = s0z*s1x - s0x*s1z;
+ this._localHitNormal.z = s0x*s1y - s0y*s1x;
+ nl = 1/Math.sqrt(this._localHitNormal.x*this._localHitNormal.x + this._localHitNormal.y*this._localHitNormal.y + this._localHitNormal.z*this._localHitNormal.z); // normalize n
+ this._localHitNormal.x *= nl;
+ this._localHitNormal.y *= nl;
+ this._localHitNormal.z *= nl;
+
+ dot02 = v0x*v2x + v0y*v2y + v0z*v2z;
+ dot12 = v1x*v2x + v1y*v2y + v1z*v2z;
+ s = (dot11*dot02 - dot01*dot12)*invDenom;
+ t = (dot00*dot12 - dot01*dot02)*invDenom;
+
+ ui1 = uvOffset + indices[i]*uvStride
+ ui2 = uvOffset + indices[j]*uvStride
+ ui3 = uvOffset + indices[k]*uvStride
+
+ u = uvs[ui1];
+ v = uvs[ui1 + 1];
+ this._hitUV.x = u + t*(uvs[ui2] - u) + s*(uvs[ui3] - u);
+ this._hitUV.y = v + t*(uvs[ui2 + 1] - v) + s*(uvs[ui3 + 1] - v);
+
+ this._faceIndex = i;
+ //TODO add back subGeometryIndex value
+ //this._subGeometryIndex = away.utils.GeometryUtils.getMeshSubGeometryIndex(subGeom);
+
+ return;
+ }
+ }
+
+ i += 3;
+ j += 3;
+ k += 3;
+ }
+ }
+
+ /**
+ * Finds the precise hit position by unprojecting the screen coordinate back unto the hit face's plane and
+ * calculating the intersection point.
+ * @param camera The camera used to render the object.
+ * @param invSceneTransform The inverse scene transformation of the hit object.
+ * @param nx The x-coordinate of the face's plane normal.
+ * @param ny The y-coordinate of the face plane normal.
+ * @param nz The z-coordinate of the face plane normal.
+ * @param px The x-coordinate of a point on the face's plane (ie a face vertex)
+ * @param py The y-coordinate of a point on the face's plane (ie a face vertex)
+ * @param pz The z-coordinate of a point on the face's plane (ie a face vertex)
+ */
+
+ private getPrecisePosition(invSceneTransform:Matrix3D, nx:number, ny:number, nz:number, px:number, py:number, pz:number)
+ {
+ // calculate screen ray and find exact intersection position with triangle
+ var rx:number, ry:number, rz:number;
+ var ox:number, oy:number, oz:number;
+ var t:number;
+ var raw:Array = Matrix3DUtils.RAW_DATA_CONTAINER;
+ var cx:number = this._rayPos.x, cy:number = this._rayPos.y, cz:number = this._rayPos.z;
+
+ // unprojected projection point, gives ray dir in cam space
+ ox = this._rayDir.x;
+ oy = this._rayDir.y;
+ oz = this._rayDir.z;
+
+ // transform ray dir and origin (cam pos) to object space
+ //invSceneTransform.copyRawDataTo( raw );
+ invSceneTransform.copyRawDataTo(raw);
+ rx = raw[0]*ox + raw[4]*oy + raw[8]*oz;
+ ry = raw[1]*ox + raw[5]*oy + raw[9]*oz;
+ rz = raw[2]*ox + raw[6]*oy + raw[10]*oz;
+
+ ox = raw[0]*cx + raw[4]*cy + raw[8]*cz + raw[12];
+ oy = raw[1]*cx + raw[5]*cy + raw[9]*cz + raw[13];
+ oz = raw[2]*cx + raw[6]*cy + raw[10]*cz + raw[14];
+
+ t = ((px - ox)*nx + (py - oy)*ny + (pz - oz)*nz)/(rx*nx + ry*ny + rz*nz);
+
+ this._localHitPosition.x = ox + rx*t;
+ this._localHitPosition.y = oy + ry*t;
+ this._localHitPosition.z = oz + rz*t;
+ }
+
+ public dispose()
+ {
+ this._bitmapData.dispose();
+ if (this._triangleProgram)
+ this._triangleProgram.dispose();
+
+ if (this._objectProgram)
+ this._objectProgram.dispose();
+
+ this._triangleProgram = null;
+ this._objectProgram = null;
+ this._bitmapData = null;
+ this._hitRenderable = null;
+ this._hitEntity = null;
+ }
+}
+
+export = ShaderPicker;
\ No newline at end of file
diff --git a/lib/events/AnimationStateEvent.js b/lib/events/AnimationStateEvent.js
new file mode 100755
index 000000000..dcc3ef3ac
--- /dev/null
+++ b/lib/events/AnimationStateEvent.js
@@ -0,0 +1,73 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var Event = require("awayjs-core/lib/events/Event");
+/**
+ * Dispatched to notify changes in an animation state's state.
+ */
+var AnimationStateEvent = (function (_super) {
+ __extends(AnimationStateEvent, _super);
+ /**
+ * Create a new AnimatonStateEvent
+ *
+ * @param type The event type.
+ * @param animator The animation state object that is the subject of this event.
+ * @param animationNode The animation node inside the animation state from which the event originated.
+ */
+ function AnimationStateEvent(type, animator, animationState, animationNode) {
+ _super.call(this, type);
+ this._animator = animator;
+ this._animationState = animationState;
+ this._animationNode = animationNode;
+ }
+ Object.defineProperty(AnimationStateEvent.prototype, "animator", {
+ /**
+ * The animator object that is the subject of this event.
+ */
+ get: function () {
+ return this._animator;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(AnimationStateEvent.prototype, "animationState", {
+ /**
+ * The animation state object that is the subject of this event.
+ */
+ get: function () {
+ return this._animationState;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(AnimationStateEvent.prototype, "animationNode", {
+ /**
+ * The animation node inside the animation state from which the event originated.
+ */
+ get: function () {
+ return this._animationNode;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * Clones the event.
+ *
+ * @return An exact duplicate of the current object.
+ */
+ AnimationStateEvent.prototype.clone = function () {
+ return new AnimationStateEvent(this.type, this._animator, this._animationState, this._animationNode);
+ };
+ /**
+ * Dispatched when a non-looping clip node inside an animation state reaches the end of its timeline.
+ */
+ AnimationStateEvent.PLAYBACK_COMPLETE = "playbackComplete";
+ AnimationStateEvent.TRANSITION_COMPLETE = "transitionComplete";
+ return AnimationStateEvent;
+})(Event);
+module.exports = AnimationStateEvent;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImV2ZW50cy9hbmltYXRpb25zdGF0ZWV2ZW50LnRzIl0sIm5hbWVzIjpbIkFuaW1hdGlvblN0YXRlRXZlbnQiLCJBbmltYXRpb25TdGF0ZUV2ZW50LmNvbnN0cnVjdG9yIiwiQW5pbWF0aW9uU3RhdGVFdmVudC5hbmltYXRvciIsIkFuaW1hdGlvblN0YXRlRXZlbnQuYW5pbWF0aW9uU3RhdGUiLCJBbmltYXRpb25TdGF0ZUV2ZW50LmFuaW1hdGlvbk5vZGUiLCJBbmltYXRpb25TdGF0ZUV2ZW50LmNsb25lIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFDQSxJQUFPLEtBQUssV0FBaUIsOEJBQThCLENBQUMsQ0FBQztBQUs3RCxBQUdBOztHQURHO0lBQ0csbUJBQW1CO0lBQVNBLFVBQTVCQSxtQkFBbUJBLFVBQWNBO0lBYXRDQTs7Ozs7O09BTUdBO0lBQ0hBLFNBcEJLQSxtQkFBbUJBLENBb0JaQSxJQUFXQSxFQUFFQSxRQUFxQkEsRUFBRUEsY0FBOEJBLEVBQUVBLGFBQStCQTtRQUU5R0Msa0JBQU1BLElBQUlBLENBQUNBLENBQUNBO1FBRVpBLElBQUlBLENBQUNBLFNBQVNBLEdBQUdBLFFBQVFBLENBQUNBO1FBQzFCQSxJQUFJQSxDQUFDQSxlQUFlQSxHQUFHQSxjQUFjQSxDQUFDQTtRQUN0Q0EsSUFBSUEsQ0FBQ0EsY0FBY0EsR0FBR0EsYUFBYUEsQ0FBQ0E7SUFDckNBLENBQUNBO0lBS0RELHNCQUFXQSx5Q0FBUUE7UUFIbkJBOztXQUVHQTthQUNIQTtZQUVDRSxNQUFNQSxDQUFDQSxJQUFJQSxDQUFDQSxTQUFTQSxDQUFDQTtRQUN2QkEsQ0FBQ0E7OztPQUFBRjtJQUtEQSxzQkFBV0EsK0NBQWNBO1FBSHpCQTs7V0FFR0E7YUFDSEE7WUFFQ0csTUFBTUEsQ0FBQ0EsSUFBSUEsQ0FBQ0EsZUFBZUEsQ0FBQ0E7UUFDN0JBLENBQUNBOzs7T0FBQUg7SUFLREEsc0JBQVdBLDhDQUFhQTtRQUh4QkE7O1dBRUdBO2FBQ0hBO1lBRUNJLE1BQU1BLENBQUNBLElBQUlBLENBQUNBLGNBQWNBLENBQUNBO1FBQzVCQSxDQUFDQTs7O09BQUFKO0lBRURBOzs7O09BSUdBO0lBQ0lBLG1DQUFLQSxHQUFaQTtRQUVDSyxNQUFNQSxDQUFDQSxJQUFJQSxtQkFBbUJBLENBQUNBLElBQUlBLENBQUNBLElBQUlBLEVBQUVBLElBQUlBLENBQUNBLFNBQVNBLEVBQUVBLElBQUlBLENBQUNBLGVBQWVBLEVBQUVBLElBQUlBLENBQUNBLGNBQWNBLENBQUNBLENBQUNBO0lBQ3RHQSxDQUFDQTtJQTNEREw7O09BRUdBO0lBQ1dBLHFDQUFpQkEsR0FBVUEsa0JBQWtCQSxDQUFDQTtJQUU5Q0EsdUNBQW1CQSxHQUFVQSxvQkFBb0JBLENBQUNBO0lBdURqRUEsMEJBQUNBO0FBQURBLENBOURBLEFBOERDQSxFQTlEaUMsS0FBSyxFQThEdEM7QUFFRCxBQUE2QixpQkFBcEIsbUJBQW1CLENBQUMiLCJmaWxlIjoiZXZlbnRzL0FuaW1hdGlvblN0YXRlRXZlbnQuanMiLCJzb3VyY2VSb290IjoiL1VzZXJzL3JvYmJhdGVtYW4vV2Vic3Rvcm1Qcm9qZWN0cy9hd2F5anMtcmVuZGVyZXJnbC8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQW5pbWF0aW9uTm9kZUJhc2VcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1jb3JlL2xpYi9hbmltYXRvcnMvbm9kZXMvQW5pbWF0aW9uTm9kZUJhc2VcIik7XG5pbXBvcnQgRXZlbnRcdFx0XHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1jb3JlL2xpYi9ldmVudHMvRXZlbnRcIik7XG5cbmltcG9ydCBBbmltYXRvckJhc2VcdFx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvYW5pbWF0b3JzL0FuaW1hdG9yQmFzZVwiKTtcbmltcG9ydCBJQW5pbWF0aW9uU3RhdGVcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2FuaW1hdG9ycy9zdGF0ZXMvSUFuaW1hdGlvblN0YXRlXCIpO1xuXG4vKipcbiAqIERpc3BhdGNoZWQgdG8gbm90aWZ5IGNoYW5nZXMgaW4gYW4gYW5pbWF0aW9uIHN0YXRlJ3Mgc3RhdGUuXG4gKi9cbmNsYXNzIEFuaW1hdGlvblN0YXRlRXZlbnQgZXh0ZW5kcyBFdmVudFxue1xuXHQvKipcblx0ICogRGlzcGF0Y2hlZCB3aGVuIGEgbm9uLWxvb3BpbmcgY2xpcCBub2RlIGluc2lkZSBhbiBhbmltYXRpb24gc3RhdGUgcmVhY2hlcyB0aGUgZW5kIG9mIGl0cyB0aW1lbGluZS5cblx0ICovXG5cdHB1YmxpYyBzdGF0aWMgUExBWUJBQ0tfQ09NUExFVEU6c3RyaW5nID0gXCJwbGF5YmFja0NvbXBsZXRlXCI7XG5cblx0cHVibGljIHN0YXRpYyBUUkFOU0lUSU9OX0NPTVBMRVRFOnN0cmluZyA9IFwidHJhbnNpdGlvbkNvbXBsZXRlXCI7XG5cblx0cHJpdmF0ZSBfYW5pbWF0b3I6QW5pbWF0b3JCYXNlO1xuXHRwcml2YXRlIF9hbmltYXRpb25TdGF0ZTpJQW5pbWF0aW9uU3RhdGU7XG5cdHByaXZhdGUgX2FuaW1hdGlvbk5vZGU6QW5pbWF0aW9uTm9kZUJhc2U7XG5cblx0LyoqXG5cdCAqIENyZWF0ZSBhIG5ldyA8Y29kZT5BbmltYXRvblN0YXRlRXZlbnQ8L2NvZGU+XG5cdCAqXG5cdCAqIEBwYXJhbSB0eXBlIFRoZSBldmVudCB0eXBlLlxuXHQgKiBAcGFyYW0gYW5pbWF0b3IgVGhlIGFuaW1hdGlvbiBzdGF0ZSBvYmplY3QgdGhhdCBpcyB0aGUgc3ViamVjdCBvZiB0aGlzIGV2ZW50LlxuXHQgKiBAcGFyYW0gYW5pbWF0aW9uTm9kZSBUaGUgYW5pbWF0aW9uIG5vZGUgaW5zaWRlIHRoZSBhbmltYXRpb24gc3RhdGUgZnJvbSB3aGljaCB0aGUgZXZlbnQgb3JpZ2luYXRlZC5cblx0ICovXG5cdGNvbnN0cnVjdG9yKHR5cGU6c3RyaW5nLCBhbmltYXRvcjpBbmltYXRvckJhc2UsIGFuaW1hdGlvblN0YXRlOklBbmltYXRpb25TdGF0ZSwgYW5pbWF0aW9uTm9kZTpBbmltYXRpb25Ob2RlQmFzZSlcblx0e1xuXHRcdHN1cGVyKHR5cGUpO1xuXG5cdFx0dGhpcy5fYW5pbWF0b3IgPSBhbmltYXRvcjtcblx0XHR0aGlzLl9hbmltYXRpb25TdGF0ZSA9IGFuaW1hdGlvblN0YXRlO1xuXHRcdHRoaXMuX2FuaW1hdGlvbk5vZGUgPSBhbmltYXRpb25Ob2RlO1xuXHR9XG5cblx0LyoqXG5cdCAqIFRoZSBhbmltYXRvciBvYmplY3QgdGhhdCBpcyB0aGUgc3ViamVjdCBvZiB0aGlzIGV2ZW50LlxuXHQgKi9cblx0cHVibGljIGdldCBhbmltYXRvcigpOkFuaW1hdG9yQmFzZVxuXHR7XG5cdFx0cmV0dXJuIHRoaXMuX2FuaW1hdG9yO1xuXHR9XG5cblx0LyoqXG5cdCAqIFRoZSBhbmltYXRpb24gc3RhdGUgb2JqZWN0IHRoYXQgaXMgdGhlIHN1YmplY3Qgb2YgdGhpcyBldmVudC5cblx0ICovXG5cdHB1YmxpYyBnZXQgYW5pbWF0aW9uU3RhdGUoKTpJQW5pbWF0aW9uU3RhdGVcblx0e1xuXHRcdHJldHVybiB0aGlzLl9hbmltYXRpb25TdGF0ZTtcblx0fVxuXG5cdC8qKlxuXHQgKiBUaGUgYW5pbWF0aW9uIG5vZGUgaW5zaWRlIHRoZSBhbmltYXRpb24gc3RhdGUgZnJvbSB3aGljaCB0aGUgZXZlbnQgb3JpZ2luYXRlZC5cblx0ICovXG5cdHB1YmxpYyBnZXQgYW5pbWF0aW9uTm9kZSgpOkFuaW1hdGlvbk5vZGVCYXNlXG5cdHtcblx0XHRyZXR1cm4gdGhpcy5fYW5pbWF0aW9uTm9kZTtcblx0fVxuXG5cdC8qKlxuXHQgKiBDbG9uZXMgdGhlIGV2ZW50LlxuXHQgKlxuXHQgKiBAcmV0dXJuIEFuIGV4YWN0IGR1cGxpY2F0ZSBvZiB0aGUgY3VycmVudCBvYmplY3QuXG5cdCAqL1xuXHRwdWJsaWMgY2xvbmUoKTpFdmVudFxuXHR7XG5cdFx0cmV0dXJuIG5ldyBBbmltYXRpb25TdGF0ZUV2ZW50KHRoaXMudHlwZSwgdGhpcy5fYW5pbWF0b3IsIHRoaXMuX2FuaW1hdGlvblN0YXRlLCB0aGlzLl9hbmltYXRpb25Ob2RlKTtcblx0fVxufVxuXG5leHBvcnQgPSBBbmltYXRpb25TdGF0ZUV2ZW50OyJdfQ==
\ No newline at end of file
diff --git a/lib/events/AnimationStateEvent.ts b/lib/events/AnimationStateEvent.ts
new file mode 100644
index 000000000..cc709ce9e
--- /dev/null
+++ b/lib/events/AnimationStateEvent.ts
@@ -0,0 +1,74 @@
+import AnimationNodeBase = require("awayjs-core/lib/animators/nodes/AnimationNodeBase");
+import Event = require("awayjs-core/lib/events/Event");
+
+import AnimatorBase = require("awayjs-stagegl/lib/animators/AnimatorBase");
+import IAnimationState = require("awayjs-stagegl/lib/animators/states/IAnimationState");
+
+/**
+ * Dispatched to notify changes in an animation state's state.
+ */
+class AnimationStateEvent extends Event
+{
+ /**
+ * Dispatched when a non-looping clip node inside an animation state reaches the end of its timeline.
+ */
+ public static PLAYBACK_COMPLETE:string = "playbackComplete";
+
+ public static TRANSITION_COMPLETE:string = "transitionComplete";
+
+ private _animator:AnimatorBase;
+ private _animationState:IAnimationState;
+ private _animationNode:AnimationNodeBase;
+
+ /**
+ * Create a new AnimatonStateEvent
+ *
+ * @param type The event type.
+ * @param animator The animation state object that is the subject of this event.
+ * @param animationNode The animation node inside the animation state from which the event originated.
+ */
+ constructor(type:string, animator:AnimatorBase, animationState:IAnimationState, animationNode:AnimationNodeBase)
+ {
+ super(type);
+
+ this._animator = animator;
+ this._animationState = animationState;
+ this._animationNode = animationNode;
+ }
+
+ /**
+ * The animator object that is the subject of this event.
+ */
+ public get animator():AnimatorBase
+ {
+ return this._animator;
+ }
+
+ /**
+ * The animation state object that is the subject of this event.
+ */
+ public get animationState():IAnimationState
+ {
+ return this._animationState;
+ }
+
+ /**
+ * The animation node inside the animation state from which the event originated.
+ */
+ public get animationNode():AnimationNodeBase
+ {
+ return this._animationNode;
+ }
+
+ /**
+ * Clones the event.
+ *
+ * @return An exact duplicate of the current object.
+ */
+ public clone():Event
+ {
+ return new AnimationStateEvent(this.type, this._animator, this._animationState, this._animationNode);
+ }
+}
+
+export = AnimationStateEvent;
\ No newline at end of file
diff --git a/lib/materials/methods/AmbientEnvMapMethod.js b/lib/materials/methods/AmbientEnvMapMethod.js
new file mode 100755
index 000000000..e67d79289
--- /dev/null
+++ b/lib/materials/methods/AmbientEnvMapMethod.js
@@ -0,0 +1,69 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var AmbientBasicMethod = require("awayjs-stagegl/lib/materials/methods/AmbientBasicMethod");
+var ShaderCompilerHelper = require("awayjs-stagegl/lib/materials/utils/ShaderCompilerHelper");
+/**
+ * AmbientEnvMapMethod provides a diffuse shading method that uses a diffuse irradiance environment map to
+ * approximate global lighting rather than lights.
+ */
+var AmbientEnvMapMethod = (function (_super) {
+ __extends(AmbientEnvMapMethod, _super);
+ /**
+ * Creates a new AmbientEnvMapMethod
object.
+ *
+ * @param envMap The cube environment map to use for the ambient lighting.
+ */
+ function AmbientEnvMapMethod(envMap) {
+ _super.call(this);
+ this._cubeTexture = envMap;
+ }
+ /**
+ * @inheritDoc
+ */
+ AmbientEnvMapMethod.prototype.iInitVO = function (shaderObject, methodVO) {
+ _super.prototype.iInitVO.call(this, shaderObject, methodVO);
+ methodVO.needsNormals = true;
+ };
+ Object.defineProperty(AmbientEnvMapMethod.prototype, "envMap", {
+ /**
+ * The cube environment map to use for the diffuse lighting.
+ */
+ get: function () {
+ return this._cubeTexture;
+ },
+ set: function (value) {
+ this._cubeTexture = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ AmbientEnvMapMethod.prototype.iActivate = function (shaderObject, methodVO, stage) {
+ _super.prototype.iActivate.call(this, shaderObject, methodVO, stage);
+ stage.context.activateCubeTexture(methodVO.texturesIndex, this._cubeTexture);
+ };
+ /**
+ * @inheritDoc
+ */
+ AmbientEnvMapMethod.prototype.iGetFragmentCode = function (shaderObject, methodVO, targetReg, regCache, sharedRegisters) {
+ var code = "";
+ var ambientInputRegister;
+ var cubeMapReg = regCache.getFreeTextureReg();
+ methodVO.texturesIndex = cubeMapReg.index;
+ code += ShaderCompilerHelper.getTexCubeSampleCode(targetReg, cubeMapReg, this._cubeTexture, shaderObject.useSmoothTextures, shaderObject.useMipmapping, sharedRegisters.normalFragment);
+ ambientInputRegister = regCache.getFreeFragmentConstant();
+ methodVO.fragmentConstantsIndex = ambientInputRegister.index;
+ code += "add " + targetReg + ".xyz, " + targetReg + ".xyz, " + ambientInputRegister + ".xyz\n";
+ return code;
+ };
+ return AmbientEnvMapMethod;
+})(AmbientBasicMethod);
+module.exports = AmbientEnvMapMethod;
+
+//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm1hdGVyaWFscy9tZXRob2RzL2FtYmllbnRlbnZtYXBtZXRob2QudHMiXSwibmFtZXMiOlsiQW1iaWVudEVudk1hcE1ldGhvZCIsIkFtYmllbnRFbnZNYXBNZXRob2QuY29uc3RydWN0b3IiLCJBbWJpZW50RW52TWFwTWV0aG9kLmlJbml0Vk8iLCJBbWJpZW50RW52TWFwTWV0aG9kLmVudk1hcCIsIkFtYmllbnRFbnZNYXBNZXRob2QuaUFjdGl2YXRlIiwiQW1iaWVudEVudk1hcE1ldGhvZC5pR2V0RnJhZ21lbnRDb2RlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFTQSxJQUFPLGtCQUFrQixXQUFjLHlEQUF5RCxDQUFDLENBQUM7QUFDbEcsSUFBTyxvQkFBb0IsV0FBYyx5REFBeUQsQ0FBQyxDQUFDO0FBRXBHLEFBSUE7OztHQURHO0lBQ0csbUJBQW1CO0lBQVNBLFVBQTVCQSxtQkFBbUJBLFVBQTJCQTtJQUluREE7Ozs7T0FJR0E7SUFDSEEsU0FUS0EsbUJBQW1CQSxDQVNaQSxNQUFzQkE7UUFFakNDLGlCQUFPQSxDQUFDQTtRQUNSQSxJQUFJQSxDQUFDQSxZQUFZQSxHQUFHQSxNQUFNQSxDQUFDQTtJQUM1QkEsQ0FBQ0E7SUFFREQ7O09BRUdBO0lBQ0lBLHFDQUFPQSxHQUFkQSxVQUFlQSxZQUE2QkEsRUFBRUEsUUFBaUJBO1FBRTlERSxnQkFBS0EsQ0FBQ0EsT0FBT0EsWUFBQ0EsWUFBWUEsRUFBRUEsUUFBUUEsQ0FBQ0EsQ0FBQ0E7UUFFdENBLFFBQVFBLENBQUNBLFlBQVlBLEdBQUdBLElBQUlBLENBQUNBO0lBQzlCQSxDQUFDQTtJQUtERixzQkFBV0EsdUNBQU1BO1FBSGpCQTs7V0FFR0E7YUFDSEE7WUFFQ0csTUFBTUEsQ0FBQ0EsSUFBSUEsQ0FBQ0EsWUFBWUEsQ0FBQ0E7UUFDMUJBLENBQUNBO2FBRURILFVBQWtCQSxLQUFxQkE7WUFFdENHLElBQUlBLENBQUNBLFlBQVlBLEdBQUdBLEtBQUtBLENBQUNBO1FBQzNCQSxDQUFDQTs7O09BTEFIO0lBT0RBOztPQUVHQTtJQUNJQSx1Q0FBU0EsR0FBaEJBLFVBQWlCQSxZQUE2QkEsRUFBRUEsUUFBaUJBLEVBQUVBLEtBQVdBO1FBRTdFSSxnQkFBS0EsQ0FBQ0EsU0FBU0EsWUFBQ0EsWUFBWUEsRUFBRUEsUUFBUUEsRUFBRUEsS0FBS0EsQ0FBQ0EsQ0FBQ0E7UUFFNUJBLEtBQUtBLENBQUNBLE9BQVFBLENBQUNBLG1CQUFtQkEsQ0FBQ0EsUUFBUUEsQ0FBQ0EsYUFBYUEsRUFBRUEsSUFBSUEsQ0FBQ0EsWUFBWUEsQ0FBQ0EsQ0FBQ0E7SUFDbEdBLENBQUNBO0lBRURKOztPQUVHQTtJQUNJQSw4Q0FBZ0JBLEdBQXZCQSxVQUF3QkEsWUFBNkJBLEVBQUVBLFFBQWlCQSxFQUFFQSxTQUErQkEsRUFBRUEsUUFBNEJBLEVBQUVBLGVBQWtDQTtRQUUxS0ssSUFBSUEsSUFBSUEsR0FBVUEsRUFBRUEsQ0FBQ0E7UUFDckJBLElBQUlBLG9CQUEwQ0EsQ0FBQ0E7UUFDL0NBLElBQUlBLFVBQVVBLEdBQXlCQSxRQUFRQSxDQUFDQSxpQkFBaUJBLEVBQUVBLENBQUNBO1FBQ3BFQSxRQUFRQSxDQUFDQSxhQUFhQSxHQUFHQSxVQUFVQSxDQUFDQSxLQUFLQSxDQUFDQTtRQUUxQ0EsSUFBSUEsSUFBSUEsb0JBQW9CQSxDQUFDQSxvQkFBb0JBLENBQUNBLFNBQVNBLEVBQUVBLFVBQVVBLEVBQUVBLElBQUlBLENBQUNBLFlBQVlBLEVBQUVBLFlBQVlBLENBQUNBLGlCQUFpQkEsRUFBRUEsWUFBWUEsQ0FBQ0EsYUFBYUEsRUFBRUEsZUFBZUEsQ0FBQ0EsY0FBY0EsQ0FBQ0EsQ0FBQ0E7UUFFeExBLG9CQUFvQkEsR0FBR0EsUUFBUUEsQ0FBQ0EsdUJBQXVCQSxFQUFFQSxDQUFDQTtRQUMxREEsUUFBUUEsQ0FBQ0Esc0JBQXNCQSxHQUFHQSxvQkFBb0JBLENBQUNBLEtBQUtBLENBQUNBO1FBRTdEQSxJQUFJQSxJQUFJQSxNQUFNQSxHQUFHQSxTQUFTQSxHQUFHQSxRQUFRQSxHQUFHQSxTQUFTQSxHQUFHQSxRQUFRQSxHQUFHQSxvQkFBb0JBLEdBQUdBLFFBQVFBLENBQUNBO1FBRS9GQSxNQUFNQSxDQUFDQSxJQUFJQSxDQUFDQTtJQUNiQSxDQUFDQTtJQUNGTCwwQkFBQ0E7QUFBREEsQ0FuRUEsQUFtRUNBLEVBbkVpQyxrQkFBa0IsRUFtRW5EO0FBRUQsQUFBNkIsaUJBQXBCLG1CQUFtQixDQUFDIiwiZmlsZSI6Im1hdGVyaWFscy9tZXRob2RzL0FtYmllbnRFbnZNYXBNZXRob2QuanMiLCJzb3VyY2VSb290IjoiL1VzZXJzL3JvYmJhdGVtYW4vV2Vic3Rvcm1Qcm9qZWN0cy9hd2F5anMtcmVuZGVyZXJnbC8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQ3ViZVRleHR1cmVCYXNlXHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1jb3JlL2xpYi90ZXh0dXJlcy9DdWJlVGV4dHVyZUJhc2VcIik7XG5cbmltcG9ydCBTdGFnZVx0XHRcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2NvcmUvYmFzZS9TdGFnZVwiKTtcbmltcG9ydCBJQ29udGV4dFN0YWdlR0xcdFx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL2NvcmUvc3RhZ2VnbC9JQ29udGV4dFN0YWdlR0xcIik7XG5pbXBvcnQgTWV0aG9kVk9cdFx0XHRcdFx0XHRcdD0gcmVxdWlyZShcImF3YXlqcy1zdGFnZWdsL2xpYi9tYXRlcmlhbHMvY29tcGlsYXRpb24vTWV0aG9kVk9cIik7XG5pbXBvcnQgU2hhZGVyT2JqZWN0QmFzZVx0XHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvbWF0ZXJpYWxzL2NvbXBpbGF0aW9uL1NoYWRlck9iamVjdEJhc2VcIik7XG5pbXBvcnQgU2hhZGVyUmVnaXN0ZXJDYWNoZVx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL21hdGVyaWFscy9jb21waWxhdGlvbi9TaGFkZXJSZWdpc3RlckNhY2hlXCIpO1xuaW1wb3J0IFNoYWRlclJlZ2lzdGVyRGF0YVx0XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL21hdGVyaWFscy9jb21waWxhdGlvbi9TaGFkZXJSZWdpc3RlckRhdGFcIik7XG5pbXBvcnQgU2hhZGVyUmVnaXN0ZXJFbGVtZW50XHRcdFx0PSByZXF1aXJlKFwiYXdheWpzLXN0YWdlZ2wvbGliL21hdGVyaWFscy9jb21waWxhdGlvbi9TaGFkZXJSZWdpc3RlckVsZW1lbnRcIik7XG5pbXBvcnQgQW1iaWVudEJhc2ljTWV0aG9kXHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvbWF0ZXJpYWxzL21ldGhvZHMvQW1iaWVudEJhc2ljTWV0aG9kXCIpO1xuaW1wb3J0IFNoYWRlckNvbXBpbGVySGVscGVyXHRcdFx0XHQ9IHJlcXVpcmUoXCJhd2F5anMtc3RhZ2VnbC9saWIvbWF0ZXJpYWxzL3V0aWxzL1NoYWRlckNvbXBpbGVySGVscGVyXCIpO1xuXG4vKipcbiAqIEFtYmllbnRFbnZNYXBNZXRob2QgcHJvdmlkZXMgYSBkaWZmdXNlIHNoYWRpbmcgbWV0aG9kIHRoYXQgdXNlcyBhIGRpZmZ1c2UgaXJyYWRpYW5jZSBlbnZpcm9ubWVudCBtYXAgdG9cbiAqIGFwcHJveGltYXRlIGdsb2JhbCBsaWdodGluZyByYXRoZXIgdGhhbiBsaWdodHMuXG4gKi9cbmNsYXNzIEFtYmllbnRFbnZNYXBNZXRob2QgZXh0ZW5kcyBBbWJpZW50QmFzaWNNZXRob2Rcbntcblx0cHJpdmF0ZSBfY3ViZVRleHR1cmU6Q3ViZVRleHR1cmVCYXNlO1xuXHRcblx0LyoqXG5cdCAqIENyZWF0ZXMgYSBuZXcgPGNvZGU+QW1iaWVudEVudk1hcE1ldGhvZDwvY29kZT4gb2JqZWN0LlxuXHQgKlxuXHQgKiBAcGFyYW0gZW52TWFwIFRoZSBjdWJlIGVudmlyb25tZW50IG1hcCB0byB1c2UgZm9yIHRoZSBhbWJpZW50IGxpZ2h0aW5nLlxuXHQgKi9cblx0Y29uc3RydWN0b3IoZW52TWFwOkN1YmVUZXh0dXJlQmFzZSlcblx0e1xuXHRcdHN1cGVyKCk7XG5cdFx0dGhpcy5fY3ViZVRleHR1cmUgPSBlbnZNYXA7XG5cdH1cblxuXHQvKipcblx0ICogQGluaGVyaXREb2Ncblx0ICovXG5cdHB1YmxpYyBpSW5pdFZPKHNoYWRlck9iamVjdDpTaGFkZXJPYmplY3RCYXNlLCBtZXRob2RWTzpNZXRob2RWTylcblx0e1xuXHRcdHN1cGVyLmlJbml0Vk8oc2hhZGVyT2JqZWN0LCBtZXRob2RWTyk7XG5cblx0XHRtZXRob2RWTy5uZWVkc05vcm1hbHMgPSB0cnVlO1xuXHR9XG5cdFxuXHQvKipcblx0ICogVGhlIGN1YmUgZW52aXJvbm1lbnQgbWFwIHRvIHVzZSBmb3IgdGhlIGRpZmZ1c2UgbGlnaHRpbmcuXG5cdCAqL1xuXHRwdWJsaWMgZ2V0IGVudk1hcCgpOkN1YmVUZXh0dXJlQmFzZVxuXHR7XG5cdFx0cmV0dXJuIHRoaXMuX2N1YmVUZXh0dXJlO1xuXHR9XG5cdFxuXHRwdWJsaWMgc2V0IGVudk1hcCh2YWx1ZTpDdWJlVGV4dHVyZUJhc2UpXG5cdHtcblx0XHR0aGlzLl9jdWJlVGV4dHVyZSA9IHZhbHVlO1xuXHR9XG5cdFxuXHQvKipcblx0ICogQGluaGVyaXREb2Ncblx0ICovXG5cdHB1YmxpYyBpQWN0aXZhdGUoc2hhZGVyT2JqZWN0OlNoYWRlck9iamVjdEJhc2UsIG1ldGhvZFZPOk1ldGhvZFZPLCBzdGFnZTpTdGFnZSlcblx0e1xuXHRcdHN1cGVyLmlBY3RpdmF0ZShzaGFkZXJPYmplY3QsIG1ldGhvZFZPLCBzdGFnZSk7XG5cblx0XHQoPElDb250ZXh0U3RhZ2VHTD4gc3RhZ2UuY29udGV4dCkuYWN0aXZhdGVDdWJlVGV4dHVyZShtZXRob2RWTy50ZXh0dXJlc0luZGV4LCB0aGlzLl9jdWJlVGV4dHVyZSk7XG5cdH1cblx0XG5cdC8qKlxuXHQgKiBAaW5oZXJpdERvY1xuXHQgKi9cblx0cHVibGljIGlHZXRGcmFnbWVudENvZGUoc2hhZGVyT2JqZWN0OlNoYWRlck9iamVjdEJhc2UsIG1ldGhvZFZPOk1ldGhvZFZPLCB0YXJnZXRSZWc6U2hhZGVyUmVnaXN0ZXJFbGVtZW50LCByZWdDYWNoZTpTaGFkZXJSZWdpc3RlckNhY2hlLCBzaGFyZWRSZWdpc3RlcnM6U2hhZGVyUmVnaXN0ZXJEYXRhKTpzdHJpbmdcblx0e1xuXHRcdHZhciBjb2RlOnN0cmluZyA9IFwiXCI7XG5cdFx0dmFyIGFtYmllbnRJbnB1dFJlZ2lzdGVyOlNoYWRlclJlZ2lzdGVyRWxlbWVudDtcblx0XHR2YXIgY3ViZU1hcFJlZzpTaGFkZXJSZWdpc3RlckVsZW1lbnQgPSByZWdDYWNoZS5nZXRGcmVlVGV4dHVyZVJlZygpO1xuXHRcdG1ldGhvZFZPLnRleHR1cmVzSW5kZXggPSBjdWJlTWFwUmVnLmluZGV4O1xuXHRcdFxuXHRcdGNvZGUgKz0gU2hhZGVyQ29tcGlsZXJIZWxwZXIuZ2V0VGV4Q3ViZVNhbXBsZUNvZGUodGFyZ2V0UmVnLCBjdWJlTWFwUmVnLCB0aGlzLl9jdWJlVGV4dHVyZSwgc2hhZGVyT2JqZWN0LnVzZVNtb290aFRleHR1cmVzLCBzaGFkZXJPYmplY3QudXNlTWlwbWFwcGluZywgc2hhcmVkUmVnaXN0ZXJzLm5vcm1hbEZyYWdtZW50KTtcblxuXHRcdGFtYmllbnRJbnB1dFJlZ2lzdGVyID0gcmVnQ2FjaGUuZ2V0RnJlZUZyYWdtZW50Q29uc3RhbnQoKTtcblx0XHRtZXRob2RWTy5mcmFnbWVudENvbnN0YW50c0luZGV4ID0gYW1iaWVudElucHV0UmVnaXN0ZXIuaW5kZXg7XG5cdFx0XG5cdFx0Y29kZSArPSBcImFkZCBcIiArIHRhcmdldFJlZyArIFwiLnh5eiwgXCIgKyB0YXJnZXRSZWcgKyBcIi54eXosIFwiICsgYW1iaWVudElucHV0UmVnaXN0ZXIgKyBcIi54eXpcXG5cIjtcblx0XHRcblx0XHRyZXR1cm4gY29kZTtcblx0fVxufVxuXG5leHBvcnQgPSBBbWJpZW50RW52TWFwTWV0aG9kOyJdfQ==
\ No newline at end of file
diff --git a/lib/materials/methods/AmbientEnvMapMethod.ts b/lib/materials/methods/AmbientEnvMapMethod.ts
new file mode 100644
index 000000000..7090ece2b
--- /dev/null
+++ b/lib/materials/methods/AmbientEnvMapMethod.ts
@@ -0,0 +1,86 @@
+import CubeTextureBase = require("awayjs-core/lib/textures/CubeTextureBase");
+
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import IContextStageGL = require("awayjs-stagegl/lib/core/stagegl/IContextStageGL");
+import MethodVO = require("awayjs-stagegl/lib/materials/compilation/MethodVO");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterCache = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterCache");
+import ShaderRegisterData = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterData");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+import AmbientBasicMethod = require("awayjs-stagegl/lib/materials/methods/AmbientBasicMethod");
+import ShaderCompilerHelper = require("awayjs-stagegl/lib/materials/utils/ShaderCompilerHelper");
+
+/**
+ * AmbientEnvMapMethod provides a diffuse shading method that uses a diffuse irradiance environment map to
+ * approximate global lighting rather than lights.
+ */
+class AmbientEnvMapMethod extends AmbientBasicMethod
+{
+ private _cubeTexture:CubeTextureBase;
+
+ /**
+ * Creates a new AmbientEnvMapMethod
object.
+ *
+ * @param envMap The cube environment map to use for the ambient lighting.
+ */
+ constructor(envMap:CubeTextureBase)
+ {
+ super();
+ this._cubeTexture = envMap;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iInitVO(shaderObject:ShaderObjectBase, methodVO:MethodVO)
+ {
+ super.iInitVO(shaderObject, methodVO);
+
+ methodVO.needsNormals = true;
+ }
+
+ /**
+ * The cube environment map to use for the diffuse lighting.
+ */
+ public get envMap():CubeTextureBase
+ {
+ return this._cubeTexture;
+ }
+
+ public set envMap(value:CubeTextureBase)
+ {
+ this._cubeTexture = value;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iActivate(shaderObject:ShaderObjectBase, methodVO:MethodVO, stage:Stage)
+ {
+ super.iActivate(shaderObject, methodVO, stage);
+
+ ( stage.context).activateCubeTexture(methodVO.texturesIndex, this._cubeTexture);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iGetFragmentCode(shaderObject:ShaderObjectBase, methodVO:MethodVO, targetReg:ShaderRegisterElement, regCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ var code:string = "";
+ var ambientInputRegister:ShaderRegisterElement;
+ var cubeMapReg:ShaderRegisterElement = regCache.getFreeTextureReg();
+ methodVO.texturesIndex = cubeMapReg.index;
+
+ code += ShaderCompilerHelper.getTexCubeSampleCode(targetReg, cubeMapReg, this._cubeTexture, shaderObject.useSmoothTextures, shaderObject.useMipmapping, sharedRegisters.normalFragment);
+
+ ambientInputRegister = regCache.getFreeFragmentConstant();
+ methodVO.fragmentConstantsIndex = ambientInputRegister.index;
+
+ code += "add " + targetReg + ".xyz, " + targetReg + ".xyz, " + ambientInputRegister + ".xyz\n";
+
+ return code;
+ }
+}
+
+export = AmbientEnvMapMethod;
\ No newline at end of file
diff --git a/lib/materials/methods/DiffuseCelMethod.js b/lib/materials/methods/DiffuseCelMethod.js
new file mode 100755
index 000000000..4905b6bc3
--- /dev/null
+++ b/lib/materials/methods/DiffuseCelMethod.js
@@ -0,0 +1,103 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var DiffuseCompositeMethod = require("awayjs-renderergl/lib/materials/methods/DiffuseCompositeMethod");
+/**
+ * DiffuseCelMethod provides a shading method to add diffuse cel (cartoon) shading.
+ */
+var DiffuseCelMethod = (function (_super) {
+ __extends(DiffuseCelMethod, _super);
+ /**
+ * Creates a new DiffuseCelMethod object.
+ * @param levels The amount of shadow gradations.
+ * @param baseMethod An optional diffuse method on which the cartoon shading is based. If omitted, DiffuseBasicMethod is used.
+ */
+ function DiffuseCelMethod(levels, baseMethod) {
+ var _this = this;
+ if (levels === void 0) { levels = 3; }
+ if (baseMethod === void 0) { baseMethod = null; }
+ _super.call(this, null, baseMethod);
+ this._smoothness = .1;
+ this.baseMethod._iModulateMethod = function (shaderObject, methodVO, targetReg, registerCache, sharedRegisters) { return _this.clampDiffuse(shaderObject, methodVO, targetReg, registerCache, sharedRegisters); };
+ this._levels = levels;
+ }
+ /**
+ * @inheritDoc
+ */
+ DiffuseCelMethod.prototype.iInitConstants = function (shaderObject, methodVO) {
+ var data = shaderObject.fragmentConstantData;
+ var index = methodVO.secondaryFragmentConstantsIndex;
+ _super.prototype.iInitConstants.call(this, shaderObject, methodVO);
+ data[index + 1] = 1;
+ data[index + 2] = 0;
+ };
+ Object.defineProperty(DiffuseCelMethod.prototype, "levels", {
+ /**
+ * The amount of shadow gradations.
+ */
+ get: function () {
+ return this._levels;
+ },
+ set: function (value /*uint*/) {
+ this._levels = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(DiffuseCelMethod.prototype, "smoothness", {
+ /**
+ * The smoothness of the edge between 2 shading levels.
+ */
+ get: function () {
+ return this._smoothness;
+ },
+ set: function (value) {
+ this._smoothness = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ DiffuseCelMethod.prototype.iCleanCompilationData = function () {
+ _super.prototype.iCleanCompilationData.call(this);
+ this._dataReg = null;
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseCelMethod.prototype.iGetFragmentPreLightingCode = function (shaderObject, methodVO, registerCache, sharedRegisters) {
+ this._dataReg = registerCache.getFreeFragmentConstant();
+ methodVO.secondaryFragmentConstantsIndex = this._dataReg.index * 4;
+ return _super.prototype.iGetFragmentPreLightingCode.call(this, shaderObject, methodVO, registerCache, sharedRegisters);
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseCelMethod.prototype.iActivate = function (shaderObject, methodVO, stage) {
+ _super.prototype.iActivate.call(this, shaderObject, methodVO, stage);
+ var data = shaderObject.fragmentConstantData;
+ var index = methodVO.secondaryFragmentConstantsIndex;
+ data[index] = this._levels;
+ data[index + 3] = this._smoothness;
+ };
+ /**
+ * Snaps the diffuse shading of the wrapped method to one of the levels.
+ * @param vo The MethodVO used to compile the current shader.
+ * @param t The register containing the diffuse strength in the "w" component.
+ * @param regCache The register cache used for the shader compilation.
+ * @param sharedRegisters The shared register data for this shader.
+ * @return The AGAL fragment code for the method.
+ */
+ DiffuseCelMethod.prototype.clampDiffuse = function (shaderObject, methodVO, targetReg, registerCache, sharedRegisters) {
+ return "mul " + targetReg + ".w, " + targetReg + ".w, " + this._dataReg + ".x\n" + "frc " + targetReg + ".z, " + targetReg + ".w\n" + "sub " + targetReg + ".y, " + targetReg + ".w, " + targetReg + ".z\n" + "mov " + targetReg + ".x, " + this._dataReg + ".x\n" + "sub " + targetReg + ".x, " + targetReg + ".x, " + this._dataReg + ".y\n" + "rcp " + targetReg + ".x," + targetReg + ".x\n" + "mul " + targetReg + ".w, " + targetReg + ".y, " + targetReg + ".x\n" + "sub " + targetReg + ".y, " + targetReg + ".w, " + targetReg + ".x\n" + "div " + targetReg + ".z, " + targetReg + ".z, " + this._dataReg + ".w\n" + "sat " + targetReg + ".z, " + targetReg + ".z\n" + "mul " + targetReg + ".w, " + targetReg + ".w, " + targetReg + ".z\n" + "sub " + targetReg + ".z, " + this._dataReg + ".y, " + targetReg + ".z\n" + "mul " + targetReg + ".y, " + targetReg + ".y, " + targetReg + ".z\n" + "add " + targetReg + ".w, " + targetReg + ".w, " + targetReg + ".y\n" + "sat " + targetReg + ".w, " + targetReg + ".w\n";
+ };
+ return DiffuseCelMethod;
+})(DiffuseCompositeMethod);
+module.exports = DiffuseCelMethod;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["materials/methods/diffusecelmethod.ts"],"names":["DiffuseCelMethod","DiffuseCelMethod.constructor","DiffuseCelMethod.iInitConstants","DiffuseCelMethod.levels","DiffuseCelMethod.smoothness","DiffuseCelMethod.iCleanCompilationData","DiffuseCelMethod.iGetFragmentPreLightingCode","DiffuseCelMethod.iActivate","DiffuseCelMethod.clampDiffuse"],"mappings":"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","file":"materials/methods/DiffuseCelMethod.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport IContextStageGL\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/IContextStageGL\");\nimport MethodVO\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/MethodVO\");\nimport ShaderLightingObject\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderLightingObject\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterCache\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterCache\");\nimport ShaderRegisterData\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterData\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\nimport DiffuseBasicMethod\t\t\t\t= require(\"awayjs-stagegl/lib/materials/methods/DiffuseBasicMethod\");\nimport ShaderCompilerHelper\t\t\t\t= require(\"awayjs-stagegl/lib/materials/utils/ShaderCompilerHelper\");\n\nimport DiffuseCompositeMethod\t\t\t= require(\"awayjs-renderergl/lib/materials/methods/DiffuseCompositeMethod\");\n\n/**\n * DiffuseCelMethod provides a shading method to add diffuse cel (cartoon) shading.\n */\nclass DiffuseCelMethod extends DiffuseCompositeMethod\n{\n\tprivate _levels:number /*uint*/;\n\tprivate _dataReg:ShaderRegisterElement;\n\tprivate _smoothness:number = .1;\n\n\t/**\n\t * Creates a new DiffuseCelMethod object.\n\t * @param levels The amount of shadow gradations.\n\t * @param baseMethod An optional diffuse method on which the cartoon shading is based. If omitted, DiffuseBasicMethod is used.\n\t */\n\tconstructor(levels:number /*uint*/ = 3, baseMethod:DiffuseBasicMethod = null)\n\t{\n\t\tsuper(null, baseMethod);\n\n\t\tthis.baseMethod._iModulateMethod = (shaderObject:ShaderObjectBase, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData) => this.clampDiffuse(shaderObject, methodVO, targetReg, registerCache, sharedRegisters);\n\n\t\tthis._levels = levels;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iInitConstants(shaderObject:ShaderLightingObject, methodVO:MethodVO)\n\t{\n\t\tvar data:Array<number> = shaderObject.fragmentConstantData;\n\t\tvar index:number /*int*/ = methodVO.secondaryFragmentConstantsIndex;\n\t\tsuper.iInitConstants(shaderObject, methodVO);\n\t\tdata[index + 1] = 1;\n\t\tdata[index + 2] = 0;\n\t}\n\n\t/**\n\t * The amount of shadow gradations.\n\t */\n\tpublic get levels():number /*uint*/\n\t{\n\t\treturn this._levels;\n\t}\n\n\tpublic set levels(value:number /*uint*/)\n\t{\n\t\tthis._levels = value;\n\t}\n\n\t/**\n\t * The smoothness of the edge between 2 shading levels.\n\t */\n\tpublic get smoothness():number\n\t{\n\t\treturn this._smoothness;\n\t}\n\n\tpublic set smoothness(value:number)\n\t{\n\t\tthis._smoothness = value;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iCleanCompilationData()\n\t{\n\t\tsuper.iCleanCompilationData();\n\t\tthis._dataReg = null;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iGetFragmentPreLightingCode(shaderObject:ShaderLightingObject, methodVO:MethodVO, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\tthis._dataReg = registerCache.getFreeFragmentConstant();\n\t\tmethodVO.secondaryFragmentConstantsIndex = this._dataReg.index*4;\n\n\t\treturn super.iGetFragmentPreLightingCode(shaderObject, methodVO, registerCache, sharedRegisters);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iActivate(shaderObject:ShaderLightingObject, methodVO:MethodVO, stage:Stage)\n\t{\n\t\tsuper.iActivate(shaderObject, methodVO, stage);\n\t\tvar data:Array<number> = shaderObject.fragmentConstantData;\n\t\tvar index:number /*int*/ = methodVO.secondaryFragmentConstantsIndex;\n\t\tdata[index] = this._levels;\n\t\tdata[index + 3] = this._smoothness;\n\t}\n\n\t/**\n\t * Snaps the diffuse shading of the wrapped method to one of the levels.\n\t * @param vo The MethodVO used to compile the current shader.\n\t * @param t The register containing the diffuse strength in the \"w\" component.\n\t * @param regCache The register cache used for the shader compilation.\n\t * @param sharedRegisters The shared register data for this shader.\n\t * @return The AGAL fragment code for the method.\n\t */\n\tprivate clampDiffuse(shaderObject:ShaderObjectBase, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\treturn \"mul \" + targetReg + \".w, \" + targetReg + \".w, \" + this._dataReg + \".x\\n\" +\n\t\t\t\"frc \" + targetReg + \".z, \" + targetReg + \".w\\n\" +\n\t\t\t\"sub \" + targetReg + \".y, \" + targetReg + \".w, \" + targetReg + \".z\\n\" +\n\t\t\t\"mov \" + targetReg + \".x, \" + this._dataReg + \".x\\n\" +\n\t\t\t\"sub \" + targetReg + \".x, \" + targetReg + \".x, \" + this._dataReg + \".y\\n\" +\n\t\t\t\"rcp \" + targetReg + \".x,\" + targetReg + \".x\\n\" +\n\t\t\t\"mul \" + targetReg + \".w, \" + targetReg + \".y, \" + targetReg + \".x\\n\" +\n\n\t\t\t// previous clamped strength\n\t\t\t\"sub \" + targetReg + \".y, \" + targetReg + \".w, \" + targetReg + \".x\\n\" +\n\n\t\t\t// fract/epsilon (so 0 - epsilon will become 0 - 1)\n\t\t\t\"div \" + targetReg + \".z, \" + targetReg + \".z, \" + this._dataReg + \".w\\n\" +\n\t\t\t\"sat \" + targetReg + \".z, \" + targetReg + \".z\\n\" +\n\n\t\t\t\"mul \" + targetReg + \".w, \" + targetReg + \".w, \" + targetReg + \".z\\n\" +\n\t\t\t// 1-z\n\t\t\t\"sub \" + targetReg + \".z, \" + this._dataReg + \".y, \" + targetReg + \".z\\n\" +\n\t\t\t\"mul \" + targetReg + \".y, \" + targetReg + \".y, \" + targetReg + \".z\\n\" +\n\t\t\t\"add \" + targetReg + \".w, \" + targetReg + \".w, \" + targetReg + \".y\\n\" +\n\t\t\t\"sat \" + targetReg + \".w, \" + targetReg + \".w\\n\";\n\t}\n}\n\nexport = DiffuseCelMethod;"]}
\ No newline at end of file
diff --git a/lib/materials/methods/DiffuseCelMethod.ts b/lib/materials/methods/DiffuseCelMethod.ts
new file mode 100644
index 000000000..64f2dc654
--- /dev/null
+++ b/lib/materials/methods/DiffuseCelMethod.ts
@@ -0,0 +1,141 @@
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import IContextStageGL = require("awayjs-stagegl/lib/core/stagegl/IContextStageGL");
+import MethodVO = require("awayjs-stagegl/lib/materials/compilation/MethodVO");
+import ShaderLightingObject = require("awayjs-stagegl/lib/materials/compilation/ShaderLightingObject");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterCache = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterCache");
+import ShaderRegisterData = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterData");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+import DiffuseBasicMethod = require("awayjs-stagegl/lib/materials/methods/DiffuseBasicMethod");
+import ShaderCompilerHelper = require("awayjs-stagegl/lib/materials/utils/ShaderCompilerHelper");
+
+import DiffuseCompositeMethod = require("awayjs-renderergl/lib/materials/methods/DiffuseCompositeMethod");
+
+/**
+ * DiffuseCelMethod provides a shading method to add diffuse cel (cartoon) shading.
+ */
+class DiffuseCelMethod extends DiffuseCompositeMethod
+{
+ private _levels:number /*uint*/;
+ private _dataReg:ShaderRegisterElement;
+ private _smoothness:number = .1;
+
+ /**
+ * Creates a new DiffuseCelMethod object.
+ * @param levels The amount of shadow gradations.
+ * @param baseMethod An optional diffuse method on which the cartoon shading is based. If omitted, DiffuseBasicMethod is used.
+ */
+ constructor(levels:number /*uint*/ = 3, baseMethod:DiffuseBasicMethod = null)
+ {
+ super(null, baseMethod);
+
+ this.baseMethod._iModulateMethod = (shaderObject:ShaderObjectBase, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData) => this.clampDiffuse(shaderObject, methodVO, targetReg, registerCache, sharedRegisters);
+
+ this._levels = levels;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iInitConstants(shaderObject:ShaderLightingObject, methodVO:MethodVO)
+ {
+ var data:Array = shaderObject.fragmentConstantData;
+ var index:number /*int*/ = methodVO.secondaryFragmentConstantsIndex;
+ super.iInitConstants(shaderObject, methodVO);
+ data[index + 1] = 1;
+ data[index + 2] = 0;
+ }
+
+ /**
+ * The amount of shadow gradations.
+ */
+ public get levels():number /*uint*/
+ {
+ return this._levels;
+ }
+
+ public set levels(value:number /*uint*/)
+ {
+ this._levels = value;
+ }
+
+ /**
+ * The smoothness of the edge between 2 shading levels.
+ */
+ public get smoothness():number
+ {
+ return this._smoothness;
+ }
+
+ public set smoothness(value:number)
+ {
+ this._smoothness = value;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iCleanCompilationData()
+ {
+ super.iCleanCompilationData();
+ this._dataReg = null;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iGetFragmentPreLightingCode(shaderObject:ShaderLightingObject, methodVO:MethodVO, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ this._dataReg = registerCache.getFreeFragmentConstant();
+ methodVO.secondaryFragmentConstantsIndex = this._dataReg.index*4;
+
+ return super.iGetFragmentPreLightingCode(shaderObject, methodVO, registerCache, sharedRegisters);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iActivate(shaderObject:ShaderLightingObject, methodVO:MethodVO, stage:Stage)
+ {
+ super.iActivate(shaderObject, methodVO, stage);
+ var data:Array = shaderObject.fragmentConstantData;
+ var index:number /*int*/ = methodVO.secondaryFragmentConstantsIndex;
+ data[index] = this._levels;
+ data[index + 3] = this._smoothness;
+ }
+
+ /**
+ * Snaps the diffuse shading of the wrapped method to one of the levels.
+ * @param vo The MethodVO used to compile the current shader.
+ * @param t The register containing the diffuse strength in the "w" component.
+ * @param regCache The register cache used for the shader compilation.
+ * @param sharedRegisters The shared register data for this shader.
+ * @return The AGAL fragment code for the method.
+ */
+ private clampDiffuse(shaderObject:ShaderObjectBase, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ return "mul " + targetReg + ".w, " + targetReg + ".w, " + this._dataReg + ".x\n" +
+ "frc " + targetReg + ".z, " + targetReg + ".w\n" +
+ "sub " + targetReg + ".y, " + targetReg + ".w, " + targetReg + ".z\n" +
+ "mov " + targetReg + ".x, " + this._dataReg + ".x\n" +
+ "sub " + targetReg + ".x, " + targetReg + ".x, " + this._dataReg + ".y\n" +
+ "rcp " + targetReg + ".x," + targetReg + ".x\n" +
+ "mul " + targetReg + ".w, " + targetReg + ".y, " + targetReg + ".x\n" +
+
+ // previous clamped strength
+ "sub " + targetReg + ".y, " + targetReg + ".w, " + targetReg + ".x\n" +
+
+ // fract/epsilon (so 0 - epsilon will become 0 - 1)
+ "div " + targetReg + ".z, " + targetReg + ".z, " + this._dataReg + ".w\n" +
+ "sat " + targetReg + ".z, " + targetReg + ".z\n" +
+
+ "mul " + targetReg + ".w, " + targetReg + ".w, " + targetReg + ".z\n" +
+ // 1-z
+ "sub " + targetReg + ".z, " + this._dataReg + ".y, " + targetReg + ".z\n" +
+ "mul " + targetReg + ".y, " + targetReg + ".y, " + targetReg + ".z\n" +
+ "add " + targetReg + ".w, " + targetReg + ".w, " + targetReg + ".y\n" +
+ "sat " + targetReg + ".w, " + targetReg + ".w\n";
+ }
+}
+
+export = DiffuseCelMethod;
\ No newline at end of file
diff --git a/lib/materials/methods/DiffuseCompositeMethod.js b/lib/materials/methods/DiffuseCompositeMethod.js
new file mode 100755
index 000000000..621096f87
--- /dev/null
+++ b/lib/materials/methods/DiffuseCompositeMethod.js
@@ -0,0 +1,190 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var ShadingMethodEvent = require("awayjs-stagegl/lib/events/ShadingMethodEvent");
+var DiffuseBasicMethod = require("awayjs-stagegl/lib/materials/methods/DiffuseBasicMethod");
+/**
+ * DiffuseCompositeMethod provides a base class for diffuse methods that wrap a diffuse method to alter the
+ * calculated diffuse reflection strength.
+ */
+var DiffuseCompositeMethod = (function (_super) {
+ __extends(DiffuseCompositeMethod, _super);
+ /**
+ * Creates a new DiffuseCompositeMethod
object.
+ *
+ * @param modulateMethod The method which will add the code to alter the base method's strength. It needs to have the signature clampDiffuse(t:ShaderRegisterElement, regCache:ShaderRegisterCache):string, in which t.w will contain the diffuse strength.
+ * @param baseMethod The base diffuse method on which this method's shading is based.
+ */
+ function DiffuseCompositeMethod(modulateMethod, baseMethod) {
+ var _this = this;
+ if (baseMethod === void 0) { baseMethod = null; }
+ _super.call(this);
+ this._onShaderInvalidatedDelegate = function (event) { return _this.onShaderInvalidated(event); };
+ this.pBaseMethod = baseMethod || new DiffuseBasicMethod();
+ this.pBaseMethod._iModulateMethod = modulateMethod;
+ this.pBaseMethod.addEventListener(ShadingMethodEvent.SHADER_INVALIDATED, this._onShaderInvalidatedDelegate);
+ }
+ Object.defineProperty(DiffuseCompositeMethod.prototype, "baseMethod", {
+ /**
+ * The base diffuse method on which this method's shading is based.
+ */
+ get: function () {
+ return this.pBaseMethod;
+ },
+ set: function (value) {
+ if (this.pBaseMethod == value)
+ return;
+ this.pBaseMethod.removeEventListener(ShadingMethodEvent.SHADER_INVALIDATED, this._onShaderInvalidatedDelegate);
+ this.pBaseMethod = value;
+ this.pBaseMethod.addEventListener(ShadingMethodEvent.SHADER_INVALIDATED, this._onShaderInvalidatedDelegate);
+ this.iInvalidateShaderProgram();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ DiffuseCompositeMethod.prototype.iInitVO = function (shaderObject, methodVO) {
+ this.pBaseMethod.iInitVO(shaderObject, methodVO);
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseCompositeMethod.prototype.iInitConstants = function (shaderObject, methodVO) {
+ this.pBaseMethod.iInitConstants(shaderObject, methodVO);
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseCompositeMethod.prototype.dispose = function () {
+ this.pBaseMethod.removeEventListener(ShadingMethodEvent.SHADER_INVALIDATED, this._onShaderInvalidatedDelegate);
+ this.pBaseMethod.dispose();
+ };
+ Object.defineProperty(DiffuseCompositeMethod.prototype, "texture", {
+ /**
+ * @inheritDoc
+ */
+ get: function () {
+ return this.pBaseMethod.texture;
+ },
+ /**
+ * @inheritDoc
+ */
+ set: function (value) {
+ this.pBaseMethod.texture = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(DiffuseCompositeMethod.prototype, "diffuseColor", {
+ /**
+ * @inheritDoc
+ */
+ get: function () {
+ return this.pBaseMethod.diffuseColor;
+ },
+ /**
+ * @inheritDoc
+ */
+ set: function (value) {
+ this.pBaseMethod.diffuseColor = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(DiffuseCompositeMethod.prototype, "ambientColor", {
+ /**
+ * @inheritDoc
+ */
+ get: function () {
+ return this.pBaseMethod.ambientColor;
+ },
+ /**
+ * @inheritDoc
+ */
+ set: function (value) {
+ this.pBaseMethod.ambientColor = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ DiffuseCompositeMethod.prototype.iGetFragmentPreLightingCode = function (shaderObject, methodVO, registerCache, sharedRegisters) {
+ return this.pBaseMethod.iGetFragmentPreLightingCode(shaderObject, methodVO, registerCache, sharedRegisters);
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseCompositeMethod.prototype.iGetFragmentCodePerLight = function (shaderObject, methodVO, lightDirReg, lightColReg, registerCache, sharedRegisters) {
+ var code = this.pBaseMethod.iGetFragmentCodePerLight(shaderObject, methodVO, lightDirReg, lightColReg, registerCache, sharedRegisters);
+ this._pTotalLightColorReg = this.pBaseMethod._pTotalLightColorReg;
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseCompositeMethod.prototype.iGetFragmentCodePerProbe = function (shaderObject, methodVO, cubeMapReg, weightRegister, registerCache, sharedRegisters) {
+ var code = this.pBaseMethod.iGetFragmentCodePerProbe(shaderObject, methodVO, cubeMapReg, weightRegister, registerCache, sharedRegisters);
+ this._pTotalLightColorReg = this.pBaseMethod._pTotalLightColorReg;
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseCompositeMethod.prototype.iActivate = function (shaderObject, methodVO, stage) {
+ this.pBaseMethod.iActivate(shaderObject, methodVO, stage);
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseCompositeMethod.prototype.iSetRenderState = function (shaderObject, methodVO, renderable, stage, camera) {
+ this.pBaseMethod.iSetRenderState(shaderObject, methodVO, renderable, stage, camera);
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseCompositeMethod.prototype.iDeactivate = function (shaderObject, methodVO, stage) {
+ this.pBaseMethod.iDeactivate(shaderObject, methodVO, stage);
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseCompositeMethod.prototype.iGetVertexCode = function (shaderObject, methodVO, registerCache, sharedRegisters) {
+ return this.pBaseMethod.iGetVertexCode(shaderObject, methodVO, registerCache, sharedRegisters);
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseCompositeMethod.prototype.iGetFragmentPostLightingCode = function (shaderObject, methodVO, targetReg, registerCache, sharedRegisters) {
+ return this.pBaseMethod.iGetFragmentPostLightingCode(shaderObject, methodVO, targetReg, registerCache, sharedRegisters);
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseCompositeMethod.prototype.iReset = function () {
+ this.pBaseMethod.iReset();
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseCompositeMethod.prototype.iCleanCompilationData = function () {
+ _super.prototype.iCleanCompilationData.call(this);
+ this.pBaseMethod.iCleanCompilationData();
+ };
+ /**
+ * Called when the base method's shader code is invalidated.
+ */
+ DiffuseCompositeMethod.prototype.onShaderInvalidated = function (event) {
+ this.iInvalidateShaderProgram();
+ };
+ return DiffuseCompositeMethod;
+})(DiffuseBasicMethod);
+module.exports = DiffuseCompositeMethod;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["materials/methods/diffusecompositemethod.ts"],"names":["DiffuseCompositeMethod","DiffuseCompositeMethod.constructor","DiffuseCompositeMethod.baseMethod","DiffuseCompositeMethod.iInitVO","DiffuseCompositeMethod.iInitConstants","DiffuseCompositeMethod.dispose","DiffuseCompositeMethod.texture","DiffuseCompositeMethod.diffuseColor","DiffuseCompositeMethod.ambientColor","DiffuseCompositeMethod.iGetFragmentPreLightingCode","DiffuseCompositeMethod.iGetFragmentCodePerLight","DiffuseCompositeMethod.iGetFragmentCodePerProbe","DiffuseCompositeMethod.iActivate","DiffuseCompositeMethod.iSetRenderState","DiffuseCompositeMethod.iDeactivate","DiffuseCompositeMethod.iGetVertexCode","DiffuseCompositeMethod.iGetFragmentPostLightingCode","DiffuseCompositeMethod.iReset","DiffuseCompositeMethod.iCleanCompilationData","DiffuseCompositeMethod.onShaderInvalidated"],"mappings":"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","file":"materials/methods/DiffuseCompositeMethod.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Texture2DBase\t\t\t\t\t= require(\"awayjs-core/lib/textures/Texture2DBase\");\nimport Camera\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Camera\");\n\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport RenderableBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/RenderableBase\");\nimport ShadingMethodEvent\t\t\t\t= require(\"awayjs-stagegl/lib/events/ShadingMethodEvent\");\nimport MethodVO\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/MethodVO\");\nimport ShaderLightingObject\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderLightingObject\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterCache\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterCache\");\nimport ShaderRegisterData\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterData\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\nimport DiffuseBasicMethod\t\t\t\t= require(\"awayjs-stagegl/lib/materials/methods/DiffuseBasicMethod\");\n\n/**\n * DiffuseCompositeMethod provides a base class for diffuse methods that wrap a diffuse method to alter the\n * calculated diffuse reflection strength.\n */\nclass DiffuseCompositeMethod extends DiffuseBasicMethod\n{\n\tpublic pBaseMethod:DiffuseBasicMethod;\n\n\tprivate _onShaderInvalidatedDelegate:Function;\n\n\t/**\n\t * Creates a new <code>DiffuseCompositeMethod</code> object.\n\t *\n\t * @param modulateMethod The method which will add the code to alter the base method's strength. It needs to have the signature clampDiffuse(t:ShaderRegisterElement, regCache:ShaderRegisterCache):string, in which t.w will contain the diffuse strength.\n\t * @param baseMethod The base diffuse method on which this method's shading is based.\n\t */\n\tconstructor(modulateMethod:(shaderObject:ShaderObjectBase, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData) => string, baseMethod:DiffuseBasicMethod = null)\n\t{\n\t\tsuper();\n\n\t\tthis._onShaderInvalidatedDelegate = (event:ShadingMethodEvent) => this.onShaderInvalidated(event);\n\n\t\tthis.pBaseMethod = baseMethod || new DiffuseBasicMethod();\n\t\tthis.pBaseMethod._iModulateMethod = modulateMethod;\n\t\tthis.pBaseMethod.addEventListener(ShadingMethodEvent.SHADER_INVALIDATED, this._onShaderInvalidatedDelegate);\n\t}\n\n\t/**\n\t * The base diffuse method on which this method's shading is based.\n\t */\n\tpublic get baseMethod():DiffuseBasicMethod\n\t{\n\t\treturn this.pBaseMethod;\n\t}\n\n\tpublic set baseMethod(value:DiffuseBasicMethod)\n\t{\n\t\tif (this.pBaseMethod == value)\n\t\t\treturn;\n\n\t\tthis.pBaseMethod.removeEventListener(ShadingMethodEvent.SHADER_INVALIDATED, this._onShaderInvalidatedDelegate);\n\t\tthis.pBaseMethod = value;\n\t\tthis.pBaseMethod.addEventListener(ShadingMethodEvent.SHADER_INVALIDATED, this._onShaderInvalidatedDelegate);\n\t\tthis.iInvalidateShaderProgram();\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iInitVO(shaderObject:ShaderLightingObject, methodVO:MethodVO)\n\t{\n\t\tthis.pBaseMethod.iInitVO(shaderObject, methodVO);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iInitConstants(shaderObject:ShaderLightingObject, methodVO:MethodVO)\n\t{\n\t\tthis.pBaseMethod.iInitConstants(shaderObject, methodVO);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic dispose()\n\t{\n\t\tthis.pBaseMethod.removeEventListener(ShadingMethodEvent.SHADER_INVALIDATED, this._onShaderInvalidatedDelegate);\n\t\tthis.pBaseMethod.dispose();\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic get texture():Texture2DBase\n\t{\n\t\treturn this.pBaseMethod.texture;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic set texture(value:Texture2DBase)\n\t{\n\t\tthis.pBaseMethod.texture = value;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic get diffuseColor():number\n\t{\n\t\treturn this.pBaseMethod.diffuseColor;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic set diffuseColor(value:number)\n\t{\n\t\tthis.pBaseMethod.diffuseColor = value;\n\t}\n\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic get ambientColor():number\n\t{\n\t\treturn this.pBaseMethod.ambientColor;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic set ambientColor(value:number)\n\t{\n\t\tthis.pBaseMethod.ambientColor = value;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iGetFragmentPreLightingCode(shaderObject:ShaderLightingObject, methodVO:MethodVO, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\treturn this.pBaseMethod.iGetFragmentPreLightingCode(shaderObject, methodVO, registerCache, sharedRegisters);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iGetFragmentCodePerLight(shaderObject:ShaderLightingObject, methodVO:MethodVO, lightDirReg:ShaderRegisterElement, lightColReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\tvar code:string = this.pBaseMethod.iGetFragmentCodePerLight(shaderObject, methodVO, lightDirReg, lightColReg, registerCache, sharedRegisters);\n\t\tthis._pTotalLightColorReg = this.pBaseMethod._pTotalLightColorReg;\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iGetFragmentCodePerProbe(shaderObject:ShaderLightingObject, methodVO:MethodVO, cubeMapReg:ShaderRegisterElement, weightRegister:string, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\tvar code:string = this.pBaseMethod.iGetFragmentCodePerProbe(shaderObject, methodVO, cubeMapReg, weightRegister, registerCache, sharedRegisters);\n\t\tthis._pTotalLightColorReg = this.pBaseMethod._pTotalLightColorReg;\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iActivate(shaderObject:ShaderLightingObject, methodVO:MethodVO, stage:Stage)\n\t{\n\t\tthis.pBaseMethod.iActivate(shaderObject, methodVO, stage);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iSetRenderState(shaderObject:ShaderLightingObject, methodVO:MethodVO, renderable:RenderableBase, stage:Stage, camera:Camera)\n\t{\n\t\tthis.pBaseMethod.iSetRenderState(shaderObject, methodVO, renderable, stage, camera);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iDeactivate(shaderObject:ShaderLightingObject, methodVO:MethodVO, stage:Stage)\n\t{\n\t\tthis.pBaseMethod.iDeactivate(shaderObject, methodVO, stage);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iGetVertexCode(shaderObject:ShaderObjectBase, methodVO:MethodVO, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\treturn this.pBaseMethod.iGetVertexCode(shaderObject, methodVO, registerCache, sharedRegisters);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iGetFragmentPostLightingCode(shaderObject:ShaderLightingObject, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\treturn this.pBaseMethod.iGetFragmentPostLightingCode(shaderObject, methodVO, targetReg, registerCache, sharedRegisters);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iReset()\n\t{\n\t\tthis.pBaseMethod.iReset();\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iCleanCompilationData()\n\t{\n\t\tsuper.iCleanCompilationData();\n\t\tthis.pBaseMethod.iCleanCompilationData();\n\t}\n\n\t/**\n\t * Called when the base method's shader code is invalidated.\n\t */\n\tprivate onShaderInvalidated(event:ShadingMethodEvent)\n\t{\n\t\tthis.iInvalidateShaderProgram();\n\t}\n}\n\nexport = DiffuseCompositeMethod;"]}
\ No newline at end of file
diff --git a/lib/materials/methods/DiffuseCompositeMethod.ts b/lib/materials/methods/DiffuseCompositeMethod.ts
new file mode 100755
index 000000000..32a3a1c0c
--- /dev/null
+++ b/lib/materials/methods/DiffuseCompositeMethod.ts
@@ -0,0 +1,229 @@
+import Texture2DBase = require("awayjs-core/lib/textures/Texture2DBase");
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import ShadingMethodEvent = require("awayjs-stagegl/lib/events/ShadingMethodEvent");
+import MethodVO = require("awayjs-stagegl/lib/materials/compilation/MethodVO");
+import ShaderLightingObject = require("awayjs-stagegl/lib/materials/compilation/ShaderLightingObject");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterCache = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterCache");
+import ShaderRegisterData = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterData");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+import DiffuseBasicMethod = require("awayjs-stagegl/lib/materials/methods/DiffuseBasicMethod");
+
+/**
+ * DiffuseCompositeMethod provides a base class for diffuse methods that wrap a diffuse method to alter the
+ * calculated diffuse reflection strength.
+ */
+class DiffuseCompositeMethod extends DiffuseBasicMethod
+{
+ public pBaseMethod:DiffuseBasicMethod;
+
+ private _onShaderInvalidatedDelegate:Function;
+
+ /**
+ * Creates a new DiffuseCompositeMethod
object.
+ *
+ * @param modulateMethod The method which will add the code to alter the base method's strength. It needs to have the signature clampDiffuse(t:ShaderRegisterElement, regCache:ShaderRegisterCache):string, in which t.w will contain the diffuse strength.
+ * @param baseMethod The base diffuse method on which this method's shading is based.
+ */
+ constructor(modulateMethod:(shaderObject:ShaderObjectBase, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData) => string, baseMethod:DiffuseBasicMethod = null)
+ {
+ super();
+
+ this._onShaderInvalidatedDelegate = (event:ShadingMethodEvent) => this.onShaderInvalidated(event);
+
+ this.pBaseMethod = baseMethod || new DiffuseBasicMethod();
+ this.pBaseMethod._iModulateMethod = modulateMethod;
+ this.pBaseMethod.addEventListener(ShadingMethodEvent.SHADER_INVALIDATED, this._onShaderInvalidatedDelegate);
+ }
+
+ /**
+ * The base diffuse method on which this method's shading is based.
+ */
+ public get baseMethod():DiffuseBasicMethod
+ {
+ return this.pBaseMethod;
+ }
+
+ public set baseMethod(value:DiffuseBasicMethod)
+ {
+ if (this.pBaseMethod == value)
+ return;
+
+ this.pBaseMethod.removeEventListener(ShadingMethodEvent.SHADER_INVALIDATED, this._onShaderInvalidatedDelegate);
+ this.pBaseMethod = value;
+ this.pBaseMethod.addEventListener(ShadingMethodEvent.SHADER_INVALIDATED, this._onShaderInvalidatedDelegate);
+ this.iInvalidateShaderProgram();
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iInitVO(shaderObject:ShaderLightingObject, methodVO:MethodVO)
+ {
+ this.pBaseMethod.iInitVO(shaderObject, methodVO);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iInitConstants(shaderObject:ShaderLightingObject, methodVO:MethodVO)
+ {
+ this.pBaseMethod.iInitConstants(shaderObject, methodVO);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public dispose()
+ {
+ this.pBaseMethod.removeEventListener(ShadingMethodEvent.SHADER_INVALIDATED, this._onShaderInvalidatedDelegate);
+ this.pBaseMethod.dispose();
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public get texture():Texture2DBase
+ {
+ return this.pBaseMethod.texture;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public set texture(value:Texture2DBase)
+ {
+ this.pBaseMethod.texture = value;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public get diffuseColor():number
+ {
+ return this.pBaseMethod.diffuseColor;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public set diffuseColor(value:number)
+ {
+ this.pBaseMethod.diffuseColor = value;
+ }
+
+
+ /**
+ * @inheritDoc
+ */
+ public get ambientColor():number
+ {
+ return this.pBaseMethod.ambientColor;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public set ambientColor(value:number)
+ {
+ this.pBaseMethod.ambientColor = value;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iGetFragmentPreLightingCode(shaderObject:ShaderLightingObject, methodVO:MethodVO, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ return this.pBaseMethod.iGetFragmentPreLightingCode(shaderObject, methodVO, registerCache, sharedRegisters);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iGetFragmentCodePerLight(shaderObject:ShaderLightingObject, methodVO:MethodVO, lightDirReg:ShaderRegisterElement, lightColReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ var code:string = this.pBaseMethod.iGetFragmentCodePerLight(shaderObject, methodVO, lightDirReg, lightColReg, registerCache, sharedRegisters);
+ this._pTotalLightColorReg = this.pBaseMethod._pTotalLightColorReg;
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iGetFragmentCodePerProbe(shaderObject:ShaderLightingObject, methodVO:MethodVO, cubeMapReg:ShaderRegisterElement, weightRegister:string, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ var code:string = this.pBaseMethod.iGetFragmentCodePerProbe(shaderObject, methodVO, cubeMapReg, weightRegister, registerCache, sharedRegisters);
+ this._pTotalLightColorReg = this.pBaseMethod._pTotalLightColorReg;
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iActivate(shaderObject:ShaderLightingObject, methodVO:MethodVO, stage:Stage)
+ {
+ this.pBaseMethod.iActivate(shaderObject, methodVO, stage);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iSetRenderState(shaderObject:ShaderLightingObject, methodVO:MethodVO, renderable:RenderableBase, stage:Stage, camera:Camera)
+ {
+ this.pBaseMethod.iSetRenderState(shaderObject, methodVO, renderable, stage, camera);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iDeactivate(shaderObject:ShaderLightingObject, methodVO:MethodVO, stage:Stage)
+ {
+ this.pBaseMethod.iDeactivate(shaderObject, methodVO, stage);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iGetVertexCode(shaderObject:ShaderObjectBase, methodVO:MethodVO, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ return this.pBaseMethod.iGetVertexCode(shaderObject, methodVO, registerCache, sharedRegisters);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iGetFragmentPostLightingCode(shaderObject:ShaderLightingObject, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ return this.pBaseMethod.iGetFragmentPostLightingCode(shaderObject, methodVO, targetReg, registerCache, sharedRegisters);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iReset()
+ {
+ this.pBaseMethod.iReset();
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iCleanCompilationData()
+ {
+ super.iCleanCompilationData();
+ this.pBaseMethod.iCleanCompilationData();
+ }
+
+ /**
+ * Called when the base method's shader code is invalidated.
+ */
+ private onShaderInvalidated(event:ShadingMethodEvent)
+ {
+ this.iInvalidateShaderProgram();
+ }
+}
+
+export = DiffuseCompositeMethod;
\ No newline at end of file
diff --git a/lib/materials/methods/DiffuseDepthMethod.js b/lib/materials/methods/DiffuseDepthMethod.js
new file mode 100755
index 000000000..330041fa5
--- /dev/null
+++ b/lib/materials/methods/DiffuseDepthMethod.js
@@ -0,0 +1,62 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var DiffuseBasicMethod = require("awayjs-stagegl/lib/materials/methods/DiffuseBasicMethod");
+var ShaderCompilerHelper = require("awayjs-stagegl/lib/materials/utils/ShaderCompilerHelper");
+/**
+ * DiffuseDepthMethod provides a debug method to visualise depth maps
+ */
+var DiffuseDepthMethod = (function (_super) {
+ __extends(DiffuseDepthMethod, _super);
+ /**
+ * Creates a new DiffuseBasicMethod object.
+ */
+ function DiffuseDepthMethod() {
+ _super.call(this);
+ }
+ /**
+ * @inheritDoc
+ */
+ DiffuseDepthMethod.prototype.iInitConstants = function (shaderObject, methodVO) {
+ var data = shaderObject.fragmentConstantData;
+ var index = methodVO.fragmentConstantsIndex;
+ data[index] = 1.0;
+ data[index + 1] = 1 / 255.0;
+ data[index + 2] = 1 / 65025.0;
+ data[index + 3] = 1 / 16581375.0;
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseDepthMethod.prototype.iGetFragmentPostLightingCode = function (shaderObject, methodVO, targetReg, registerCache, sharedRegisters) {
+ var code = "";
+ var temp;
+ var decReg;
+ if (!this._pUseTexture)
+ throw new Error("DiffuseDepthMethod requires texture!");
+ // incorporate input from ambient
+ if (shaderObject.numLights > 0) {
+ if (sharedRegisters.shadowTarget)
+ code += "mul " + this._pTotalLightColorReg + ".xyz, " + this._pTotalLightColorReg + ".xyz, " + sharedRegisters.shadowTarget + ".w\n";
+ code += "add " + targetReg + ".xyz, " + this._pTotalLightColorReg + ".xyz, " + targetReg + ".xyz\n" + "sat " + targetReg + ".xyz, " + targetReg + ".xyz\n";
+ registerCache.removeFragmentTempUsage(this._pTotalLightColorReg);
+ }
+ temp = shaderObject.numLights > 0 ? registerCache.getFreeFragmentVectorTemp() : targetReg;
+ this._pDiffuseInputRegister = registerCache.getFreeTextureReg();
+ methodVO.texturesIndex = this._pDiffuseInputRegister.index;
+ decReg = registerCache.getFreeFragmentConstant();
+ methodVO.fragmentConstantsIndex = decReg.index * 4;
+ code += ShaderCompilerHelper.getTex2DSampleCode(temp, sharedRegisters, this._pDiffuseInputRegister, this.texture, shaderObject.useSmoothTextures, shaderObject.repeatTextures, shaderObject.useMipmapping) + "dp4 " + temp + ".x, " + temp + ", " + decReg + "\n" + "mov " + temp + ".yz, " + temp + ".xx \n" + "mov " + temp + ".w, " + decReg + ".x\n" + "sub " + temp + ".xyz, " + decReg + ".xxx, " + temp + ".xyz\n";
+ if (shaderObject.numLights == 0)
+ return code;
+ code += "mul " + targetReg + ".xyz, " + temp + ".xyz, " + targetReg + ".xyz\n" + "mov " + targetReg + ".w, " + temp + ".w\n";
+ return code;
+ };
+ return DiffuseDepthMethod;
+})(DiffuseBasicMethod);
+module.exports = DiffuseDepthMethod;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["materials/methods/diffusedepthmethod.ts"],"names":["DiffuseDepthMethod","DiffuseDepthMethod.constructor","DiffuseDepthMethod.iInitConstants","DiffuseDepthMethod.iGetFragmentPostLightingCode"],"mappings":"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","file":"materials/methods/DiffuseDepthMethod.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import MethodVO\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/MethodVO\");\nimport ShaderLightingObject\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderLightingObject\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterCache\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterCache\");\nimport ShaderRegisterData\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterData\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\nimport DiffuseBasicMethod\t\t\t\t= require(\"awayjs-stagegl/lib/materials/methods/DiffuseBasicMethod\");\nimport ShaderCompilerHelper\t\t\t\t= require(\"awayjs-stagegl/lib/materials/utils/ShaderCompilerHelper\");\n\n/**\n * DiffuseDepthMethod provides a debug method to visualise depth maps\n */\nclass DiffuseDepthMethod extends DiffuseBasicMethod\n{\n\t/**\n\t * Creates a new DiffuseBasicMethod object.\n\t */\n\tconstructor()\n\t{\n\t\tsuper();\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iInitConstants(shaderObject:ShaderObjectBase, methodVO:MethodVO)\n\t{\n\t\tvar data:Array<number> = shaderObject.fragmentConstantData;\n\t\tvar index:number /*int*/ = methodVO.fragmentConstantsIndex;\n\t\tdata[index] = 1.0;\n\t\tdata[index + 1] = 1/255.0;\n\t\tdata[index + 2] = 1/65025.0;\n\t\tdata[index + 3] = 1/16581375.0;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iGetFragmentPostLightingCode(shaderObject:ShaderLightingObject, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\tvar code:string = \"\";\n\t\tvar temp:ShaderRegisterElement;\n\t\tvar decReg:ShaderRegisterElement;\n\n\t\tif (!this._pUseTexture)\n\t\t\tthrow new Error(\"DiffuseDepthMethod requires texture!\");\n\n\t\t// incorporate input from ambient\n\t\tif (shaderObject.numLights > 0) {\n\t\t\tif (sharedRegisters.shadowTarget)\n\t\t\t\tcode += \"mul \" + this._pTotalLightColorReg + \".xyz, \" + this._pTotalLightColorReg + \".xyz, \" + sharedRegisters.shadowTarget + \".w\\n\";\n\t\t\tcode += \"add \" + targetReg + \".xyz, \" + this._pTotalLightColorReg + \".xyz, \" + targetReg + \".xyz\\n\" +\n\t\t\t\t\"sat \" + targetReg + \".xyz, \" + targetReg + \".xyz\\n\";\n\t\t\tregisterCache.removeFragmentTempUsage(this._pTotalLightColorReg);\n\t\t}\n\n\t\ttemp = shaderObject.numLights > 0? registerCache.getFreeFragmentVectorTemp():targetReg;\n\n\t\tthis._pDiffuseInputRegister = registerCache.getFreeTextureReg();\n\t\tmethodVO.texturesIndex = this._pDiffuseInputRegister.index;\n\t\tdecReg = registerCache.getFreeFragmentConstant();\n\t\tmethodVO.fragmentConstantsIndex = decReg.index*4;\n\t\tcode += ShaderCompilerHelper.getTex2DSampleCode(temp, sharedRegisters, this._pDiffuseInputRegister, this.texture, shaderObject.useSmoothTextures, shaderObject.repeatTextures, shaderObject.useMipmapping) +\n\t\t\t\"dp4 \" + temp + \".x, \" + temp + \", \" + decReg + \"\\n\" +\n\t\t\t\"mov \" + temp + \".yz, \" + temp + \".xx\t\t\t\\n\" +\n\t\t\t\"mov \" + temp + \".w, \" + decReg + \".x\\n\" +\n\t\t\t\"sub \" + temp + \".xyz, \" + decReg + \".xxx, \" + temp + \".xyz\\n\";\n\n\t\tif (shaderObject.numLights == 0)\n\t\t\treturn code;\n\n\t\tcode += \"mul \" + targetReg + \".xyz, \" + temp + \".xyz, \" + targetReg + \".xyz\\n\" +\n\t\t\t\"mov \" + targetReg + \".w, \" + temp + \".w\\n\";\n\n\t\treturn code;\n\t}\n}\n\nexport = DiffuseDepthMethod;"]}
\ No newline at end of file
diff --git a/lib/materials/methods/DiffuseDepthMethod.ts b/lib/materials/methods/DiffuseDepthMethod.ts
new file mode 100644
index 000000000..513a7a50a
--- /dev/null
+++ b/lib/materials/methods/DiffuseDepthMethod.ts
@@ -0,0 +1,79 @@
+import MethodVO = require("awayjs-stagegl/lib/materials/compilation/MethodVO");
+import ShaderLightingObject = require("awayjs-stagegl/lib/materials/compilation/ShaderLightingObject");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterCache = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterCache");
+import ShaderRegisterData = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterData");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+import DiffuseBasicMethod = require("awayjs-stagegl/lib/materials/methods/DiffuseBasicMethod");
+import ShaderCompilerHelper = require("awayjs-stagegl/lib/materials/utils/ShaderCompilerHelper");
+
+/**
+ * DiffuseDepthMethod provides a debug method to visualise depth maps
+ */
+class DiffuseDepthMethod extends DiffuseBasicMethod
+{
+ /**
+ * Creates a new DiffuseBasicMethod object.
+ */
+ constructor()
+ {
+ super();
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iInitConstants(shaderObject:ShaderObjectBase, methodVO:MethodVO)
+ {
+ var data:Array = shaderObject.fragmentConstantData;
+ var index:number /*int*/ = methodVO.fragmentConstantsIndex;
+ data[index] = 1.0;
+ data[index + 1] = 1/255.0;
+ data[index + 2] = 1/65025.0;
+ data[index + 3] = 1/16581375.0;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iGetFragmentPostLightingCode(shaderObject:ShaderLightingObject, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ var code:string = "";
+ var temp:ShaderRegisterElement;
+ var decReg:ShaderRegisterElement;
+
+ if (!this._pUseTexture)
+ throw new Error("DiffuseDepthMethod requires texture!");
+
+ // incorporate input from ambient
+ if (shaderObject.numLights > 0) {
+ if (sharedRegisters.shadowTarget)
+ code += "mul " + this._pTotalLightColorReg + ".xyz, " + this._pTotalLightColorReg + ".xyz, " + sharedRegisters.shadowTarget + ".w\n";
+ code += "add " + targetReg + ".xyz, " + this._pTotalLightColorReg + ".xyz, " + targetReg + ".xyz\n" +
+ "sat " + targetReg + ".xyz, " + targetReg + ".xyz\n";
+ registerCache.removeFragmentTempUsage(this._pTotalLightColorReg);
+ }
+
+ temp = shaderObject.numLights > 0? registerCache.getFreeFragmentVectorTemp():targetReg;
+
+ this._pDiffuseInputRegister = registerCache.getFreeTextureReg();
+ methodVO.texturesIndex = this._pDiffuseInputRegister.index;
+ decReg = registerCache.getFreeFragmentConstant();
+ methodVO.fragmentConstantsIndex = decReg.index*4;
+ code += ShaderCompilerHelper.getTex2DSampleCode(temp, sharedRegisters, this._pDiffuseInputRegister, this.texture, shaderObject.useSmoothTextures, shaderObject.repeatTextures, shaderObject.useMipmapping) +
+ "dp4 " + temp + ".x, " + temp + ", " + decReg + "\n" +
+ "mov " + temp + ".yz, " + temp + ".xx \n" +
+ "mov " + temp + ".w, " + decReg + ".x\n" +
+ "sub " + temp + ".xyz, " + decReg + ".xxx, " + temp + ".xyz\n";
+
+ if (shaderObject.numLights == 0)
+ return code;
+
+ code += "mul " + targetReg + ".xyz, " + temp + ".xyz, " + targetReg + ".xyz\n" +
+ "mov " + targetReg + ".w, " + temp + ".w\n";
+
+ return code;
+ }
+}
+
+export = DiffuseDepthMethod;
\ No newline at end of file
diff --git a/lib/materials/methods/DiffuseGradientMethod.js b/lib/materials/methods/DiffuseGradientMethod.js
new file mode 100755
index 000000000..1a5dc15da
--- /dev/null
+++ b/lib/materials/methods/DiffuseGradientMethod.js
@@ -0,0 +1,103 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var DiffuseBasicMethod = require("awayjs-stagegl/lib/materials/methods/DiffuseBasicMethod");
+var ShaderCompilerHelper = require("awayjs-stagegl/lib/materials/utils/ShaderCompilerHelper");
+/**
+ * DiffuseGradientMethod is an alternative to DiffuseBasicMethod in which the shading can be modulated with a gradient
+ * to introduce color-tinted shading as opposed to the single-channel diffuse strength. This can be used as a crude
+ * approximation to subsurface scattering (for instance, the mid-range shading for skin can be tinted red to similate
+ * scattered light within the skin attributing to the final colour)
+ */
+var DiffuseGradientMethod = (function (_super) {
+ __extends(DiffuseGradientMethod, _super);
+ /**
+ * Creates a new DiffuseGradientMethod object.
+ * @param gradient A texture that contains the light colour based on the angle. This can be used to change
+ * the light colour due to subsurface scattering when the surface faces away from the light.
+ */
+ function DiffuseGradientMethod(gradient) {
+ _super.call(this);
+ this._gradient = gradient;
+ }
+ Object.defineProperty(DiffuseGradientMethod.prototype, "gradient", {
+ /**
+ * A texture that contains the light colour based on the angle. This can be used to change the light colour
+ * due to subsurface scattering when the surface faces away from the light.
+ */
+ get: function () {
+ return this._gradient;
+ },
+ set: function (value) {
+ if (value.hasMipmaps != this._gradient.hasMipmaps || value.format != this._gradient.format)
+ this.iInvalidateShaderProgram();
+ this._gradient = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ DiffuseGradientMethod.prototype.iCleanCompilationData = function () {
+ _super.prototype.iCleanCompilationData.call(this);
+ this._gradientTextureRegister = null;
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseGradientMethod.prototype.iGetFragmentPreLightingCode = function (shaderObject, methodVO, registerCache, sharedRegisters) {
+ var code = _super.prototype.iGetFragmentPreLightingCode.call(this, shaderObject, methodVO, registerCache, sharedRegisters);
+ this._pIsFirstLight = true;
+ if (shaderObject.numLights > 0) {
+ this._gradientTextureRegister = registerCache.getFreeTextureReg();
+ methodVO.secondaryTexturesIndex = this._gradientTextureRegister.index;
+ }
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseGradientMethod.prototype.iGetFragmentCodePerLight = function (shaderObject, methodVO, lightDirReg, lightColReg, registerCache, sharedRegisters) {
+ var code = "";
+ var t;
+ // write in temporary if not first light, so we can add to total diffuse colour
+ if (this._pIsFirstLight)
+ t = this._pTotalLightColorReg;
+ else {
+ t = registerCache.getFreeFragmentVectorTemp();
+ registerCache.addFragmentTempUsages(t, 1);
+ }
+ code += "dp3 " + t + ".w, " + lightDirReg + ".xyz, " + sharedRegisters.normalFragment + ".xyz\n" + "mul " + t + ".w, " + t + ".w, " + sharedRegisters.commons + ".x\n" + "add " + t + ".w, " + t + ".w, " + sharedRegisters.commons + ".x\n" + "mul " + t + ".xyz, " + t + ".w, " + lightDirReg + ".w\n";
+ if (this._iModulateMethod != null)
+ code += this._iModulateMethod(shaderObject, methodVO, t, registerCache, sharedRegisters);
+ code += ShaderCompilerHelper.getTex2DSampleCode(t, sharedRegisters, this._gradientTextureRegister, this._gradient, shaderObject.useSmoothTextures, shaderObject.repeatTextures, shaderObject.useMipmapping, t, "clamp") + "mul " + t + ".xyz, " + t + ".xyz, " + lightColReg + ".xyz\n";
+ if (!this._pIsFirstLight) {
+ code += "add " + this._pTotalLightColorReg + ".xyz, " + this._pTotalLightColorReg + ".xyz, " + t + ".xyz\n";
+ registerCache.removeFragmentTempUsage(t);
+ }
+ this._pIsFirstLight = false;
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseGradientMethod.prototype.pApplyShadow = function (shaderObject, methodVO, regCache, sharedRegisters) {
+ var t = regCache.getFreeFragmentVectorTemp();
+ return "mov " + t + ", " + sharedRegisters.shadowTarget + ".wwww\n" + ShaderCompilerHelper.getTex2DSampleCode(t, sharedRegisters, this._gradientTextureRegister, this._gradient, shaderObject.useSmoothTextures, shaderObject.repeatTextures, shaderObject.useMipmapping, t, "clamp") + "mul " + this._pTotalLightColorReg + ".xyz, " + this._pTotalLightColorReg + ", " + t + "\n";
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseGradientMethod.prototype.iActivate = function (shaderObject, methodVO, stage) {
+ _super.prototype.iActivate.call(this, shaderObject, methodVO, stage);
+ stage.context.activateTexture(methodVO.secondaryTexturesIndex, this._gradient);
+ };
+ return DiffuseGradientMethod;
+})(DiffuseBasicMethod);
+module.exports = DiffuseGradientMethod;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["materials/methods/diffusegradientmethod.ts"],"names":["DiffuseGradientMethod","DiffuseGradientMethod.constructor","DiffuseGradientMethod.gradient","DiffuseGradientMethod.iCleanCompilationData","DiffuseGradientMethod.iGetFragmentPreLightingCode","DiffuseGradientMethod.iGetFragmentCodePerLight","DiffuseGradientMethod.pApplyShadow","DiffuseGradientMethod.iActivate"],"mappings":"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","file":"materials/methods/DiffuseGradientMethod.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Texture2DBase\t\t\t\t\t= require(\"awayjs-core/lib/textures/Texture2DBase\");\n\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport IContextStageGL\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/IContextStageGL\");\nimport MethodVO\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/MethodVO\");\nimport ShaderLightingObject\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderLightingObject\");\nimport ShaderRegisterCache\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterCache\");\nimport ShaderRegisterData\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterData\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\nimport DiffuseBasicMethod\t\t\t\t= require(\"awayjs-stagegl/lib/materials/methods/DiffuseBasicMethod\");\nimport ShaderCompilerHelper\t\t\t\t= require(\"awayjs-stagegl/lib/materials/utils/ShaderCompilerHelper\");\n\n/**\n * DiffuseGradientMethod is an alternative to DiffuseBasicMethod in which the shading can be modulated with a gradient\n * to introduce color-tinted shading as opposed to the single-channel diffuse strength. This can be used as a crude\n * approximation to subsurface scattering (for instance, the mid-range shading for skin can be tinted red to similate\n * scattered light within the skin attributing to the final colour)\n */\nclass DiffuseGradientMethod extends DiffuseBasicMethod\n{\n\tprivate _gradientTextureRegister:ShaderRegisterElement;\n\tprivate _gradient:Texture2DBase;\n\n\t/**\n\t * Creates a new DiffuseGradientMethod object.\n\t * @param gradient A texture that contains the light colour based on the angle. This can be used to change\n\t * the light colour due to subsurface scattering when the surface faces away from the light.\n\t */\n\tconstructor(gradient:Texture2DBase)\n\t{\n\t\tsuper();\n\n\t\tthis._gradient = gradient;\n\t}\n\n\t/**\n\t * A texture that contains the light colour based on the angle. This can be used to change the light colour\n\t * due to subsurface scattering when the surface faces away from the light.\n\t */\n\tpublic get gradient():Texture2DBase\n\t{\n\t\treturn this._gradient;\n\t}\n\n\tpublic set gradient(value:Texture2DBase)\n\t{\n\t\tif (value.hasMipmaps != this._gradient.hasMipmaps || value.format != this._gradient.format)\n\t\t\tthis.iInvalidateShaderProgram();\n\t\tthis._gradient = value;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iCleanCompilationData()\n\t{\n\t\tsuper.iCleanCompilationData();\n\t\tthis._gradientTextureRegister = null;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iGetFragmentPreLightingCode(shaderObject:ShaderLightingObject, methodVO:MethodVO, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\tvar code:string = super.iGetFragmentPreLightingCode(shaderObject, methodVO, registerCache, sharedRegisters);\n\t\tthis._pIsFirstLight = true;\n\n\t\tif (shaderObject.numLights > 0) {\n\t\t\tthis._gradientTextureRegister = registerCache.getFreeTextureReg();\n\t\t\tmethodVO.secondaryTexturesIndex = this._gradientTextureRegister.index;\n\t\t}\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iGetFragmentCodePerLight(shaderObject:ShaderLightingObject, methodVO:MethodVO, lightDirReg:ShaderRegisterElement, lightColReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\tvar code:string = \"\";\n\t\tvar t:ShaderRegisterElement;\n\n\t\t// write in temporary if not first light, so we can add to total diffuse colour\n\t\tif (this._pIsFirstLight)\n\t\t\tt = this._pTotalLightColorReg;\n\t\telse {\n\t\t\tt = registerCache.getFreeFragmentVectorTemp();\n\t\t\tregisterCache.addFragmentTempUsages(t, 1);\n\t\t}\n\n\t\tcode += \"dp3 \" + t + \".w, \" + lightDirReg + \".xyz, \" + sharedRegisters.normalFragment + \".xyz\\n\" +\n\t\t\t\"mul \" + t + \".w, \" + t + \".w, \" + sharedRegisters.commons + \".x\\n\" +\n\t\t\t\"add \" + t + \".w, \" + t + \".w, \" + sharedRegisters.commons + \".x\\n\" +\n\t\t\t\"mul \" + t + \".xyz, \" + t + \".w, \" + lightDirReg + \".w\\n\";\n\n\t\tif (this._iModulateMethod != null)\n\t\t\tcode += this._iModulateMethod(shaderObject, methodVO, t, registerCache, sharedRegisters);\n\n\t\tcode += ShaderCompilerHelper.getTex2DSampleCode(t, sharedRegisters, this._gradientTextureRegister, this._gradient, shaderObject.useSmoothTextures, shaderObject.repeatTextures, shaderObject.useMipmapping, t, \"clamp\") +\n\t\t\t//\t\t\t\t\t\"mul \" + t + \".xyz, \" + t + \".xyz, \" + t + \".w\\n\" +\n\t\t\t\"mul \" + t + \".xyz, \" + t + \".xyz, \" + lightColReg + \".xyz\\n\";\n\n\t\tif (!this._pIsFirstLight) {\n\t\t\tcode += \"add \" + this._pTotalLightColorReg + \".xyz, \" + this._pTotalLightColorReg + \".xyz, \" + t + \".xyz\\n\";\n\t\t\tregisterCache.removeFragmentTempUsage(t);\n\t\t}\n\n\t\tthis._pIsFirstLight = false;\n\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic pApplyShadow(shaderObject:ShaderLightingObject, methodVO:MethodVO, regCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\tvar t:ShaderRegisterElement = regCache.getFreeFragmentVectorTemp();\n\n\t\treturn \"mov \" + t + \", \" + sharedRegisters.shadowTarget + \".wwww\\n\" +\n\t\t\tShaderCompilerHelper.getTex2DSampleCode(t, sharedRegisters, this._gradientTextureRegister, this._gradient, shaderObject.useSmoothTextures, shaderObject.repeatTextures, shaderObject.useMipmapping, t, \"clamp\") +\n\t\t\t\"mul \" + this._pTotalLightColorReg + \".xyz, \" + this._pTotalLightColorReg + \", \" + t + \"\\n\";\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iActivate(shaderObject:ShaderLightingObject, methodVO:MethodVO, stage:Stage)\n\t{\n\t\tsuper.iActivate(shaderObject, methodVO, stage);\n\n\t\t(<IContextStageGL> stage.context).activateTexture(methodVO.secondaryTexturesIndex, this._gradient);\n\t}\n}\n\nexport = DiffuseGradientMethod;"]}
\ No newline at end of file
diff --git a/lib/materials/methods/DiffuseGradientMethod.ts b/lib/materials/methods/DiffuseGradientMethod.ts
new file mode 100644
index 000000000..5c51f52e2
--- /dev/null
+++ b/lib/materials/methods/DiffuseGradientMethod.ts
@@ -0,0 +1,137 @@
+import Texture2DBase = require("awayjs-core/lib/textures/Texture2DBase");
+
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import IContextStageGL = require("awayjs-stagegl/lib/core/stagegl/IContextStageGL");
+import MethodVO = require("awayjs-stagegl/lib/materials/compilation/MethodVO");
+import ShaderLightingObject = require("awayjs-stagegl/lib/materials/compilation/ShaderLightingObject");
+import ShaderRegisterCache = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterCache");
+import ShaderRegisterData = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterData");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+import DiffuseBasicMethod = require("awayjs-stagegl/lib/materials/methods/DiffuseBasicMethod");
+import ShaderCompilerHelper = require("awayjs-stagegl/lib/materials/utils/ShaderCompilerHelper");
+
+/**
+ * DiffuseGradientMethod is an alternative to DiffuseBasicMethod in which the shading can be modulated with a gradient
+ * to introduce color-tinted shading as opposed to the single-channel diffuse strength. This can be used as a crude
+ * approximation to subsurface scattering (for instance, the mid-range shading for skin can be tinted red to similate
+ * scattered light within the skin attributing to the final colour)
+ */
+class DiffuseGradientMethod extends DiffuseBasicMethod
+{
+ private _gradientTextureRegister:ShaderRegisterElement;
+ private _gradient:Texture2DBase;
+
+ /**
+ * Creates a new DiffuseGradientMethod object.
+ * @param gradient A texture that contains the light colour based on the angle. This can be used to change
+ * the light colour due to subsurface scattering when the surface faces away from the light.
+ */
+ constructor(gradient:Texture2DBase)
+ {
+ super();
+
+ this._gradient = gradient;
+ }
+
+ /**
+ * A texture that contains the light colour based on the angle. This can be used to change the light colour
+ * due to subsurface scattering when the surface faces away from the light.
+ */
+ public get gradient():Texture2DBase
+ {
+ return this._gradient;
+ }
+
+ public set gradient(value:Texture2DBase)
+ {
+ if (value.hasMipmaps != this._gradient.hasMipmaps || value.format != this._gradient.format)
+ this.iInvalidateShaderProgram();
+ this._gradient = value;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iCleanCompilationData()
+ {
+ super.iCleanCompilationData();
+ this._gradientTextureRegister = null;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iGetFragmentPreLightingCode(shaderObject:ShaderLightingObject, methodVO:MethodVO, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ var code:string = super.iGetFragmentPreLightingCode(shaderObject, methodVO, registerCache, sharedRegisters);
+ this._pIsFirstLight = true;
+
+ if (shaderObject.numLights > 0) {
+ this._gradientTextureRegister = registerCache.getFreeTextureReg();
+ methodVO.secondaryTexturesIndex = this._gradientTextureRegister.index;
+ }
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iGetFragmentCodePerLight(shaderObject:ShaderLightingObject, methodVO:MethodVO, lightDirReg:ShaderRegisterElement, lightColReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ var code:string = "";
+ var t:ShaderRegisterElement;
+
+ // write in temporary if not first light, so we can add to total diffuse colour
+ if (this._pIsFirstLight)
+ t = this._pTotalLightColorReg;
+ else {
+ t = registerCache.getFreeFragmentVectorTemp();
+ registerCache.addFragmentTempUsages(t, 1);
+ }
+
+ code += "dp3 " + t + ".w, " + lightDirReg + ".xyz, " + sharedRegisters.normalFragment + ".xyz\n" +
+ "mul " + t + ".w, " + t + ".w, " + sharedRegisters.commons + ".x\n" +
+ "add " + t + ".w, " + t + ".w, " + sharedRegisters.commons + ".x\n" +
+ "mul " + t + ".xyz, " + t + ".w, " + lightDirReg + ".w\n";
+
+ if (this._iModulateMethod != null)
+ code += this._iModulateMethod(shaderObject, methodVO, t, registerCache, sharedRegisters);
+
+ code += ShaderCompilerHelper.getTex2DSampleCode(t, sharedRegisters, this._gradientTextureRegister, this._gradient, shaderObject.useSmoothTextures, shaderObject.repeatTextures, shaderObject.useMipmapping, t, "clamp") +
+ // "mul " + t + ".xyz, " + t + ".xyz, " + t + ".w\n" +
+ "mul " + t + ".xyz, " + t + ".xyz, " + lightColReg + ".xyz\n";
+
+ if (!this._pIsFirstLight) {
+ code += "add " + this._pTotalLightColorReg + ".xyz, " + this._pTotalLightColorReg + ".xyz, " + t + ".xyz\n";
+ registerCache.removeFragmentTempUsage(t);
+ }
+
+ this._pIsFirstLight = false;
+
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public pApplyShadow(shaderObject:ShaderLightingObject, methodVO:MethodVO, regCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ var t:ShaderRegisterElement = regCache.getFreeFragmentVectorTemp();
+
+ return "mov " + t + ", " + sharedRegisters.shadowTarget + ".wwww\n" +
+ ShaderCompilerHelper.getTex2DSampleCode(t, sharedRegisters, this._gradientTextureRegister, this._gradient, shaderObject.useSmoothTextures, shaderObject.repeatTextures, shaderObject.useMipmapping, t, "clamp") +
+ "mul " + this._pTotalLightColorReg + ".xyz, " + this._pTotalLightColorReg + ", " + t + "\n";
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iActivate(shaderObject:ShaderLightingObject, methodVO:MethodVO, stage:Stage)
+ {
+ super.iActivate(shaderObject, methodVO, stage);
+
+ ( stage.context).activateTexture(methodVO.secondaryTexturesIndex, this._gradient);
+ }
+}
+
+export = DiffuseGradientMethod;
\ No newline at end of file
diff --git a/lib/materials/methods/DiffuseLightMapMethod.js b/lib/materials/methods/DiffuseLightMapMethod.js
new file mode 100755
index 000000000..8cccaeafe
--- /dev/null
+++ b/lib/materials/methods/DiffuseLightMapMethod.js
@@ -0,0 +1,115 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var ShaderCompilerHelper = require("awayjs-stagegl/lib/materials/utils/ShaderCompilerHelper");
+var DiffuseCompositeMethod = require("awayjs-renderergl/lib/materials/methods/DiffuseCompositeMethod");
+/**
+ * DiffuseLightMapMethod provides a diffuse shading method that uses a light map to modulate the calculated diffuse
+ * lighting. It is different from EffectLightMapMethod in that the latter modulates the entire calculated pixel color, rather
+ * than only the diffuse lighting value.
+ */
+var DiffuseLightMapMethod = (function (_super) {
+ __extends(DiffuseLightMapMethod, _super);
+ /**
+ * Creates a new DiffuseLightMapMethod method.
+ *
+ * @param lightMap The texture containing the light map.
+ * @param blendMode The blend mode with which the light map should be applied to the lighting result.
+ * @param useSecondaryUV Indicates whether the secondary UV set should be used to map the light map.
+ * @param baseMethod The diffuse method used to calculate the regular diffuse-based lighting.
+ */
+ function DiffuseLightMapMethod(lightMap, blendMode, useSecondaryUV, baseMethod) {
+ if (blendMode === void 0) { blendMode = "multiply"; }
+ if (useSecondaryUV === void 0) { useSecondaryUV = false; }
+ if (baseMethod === void 0) { baseMethod = null; }
+ _super.call(this, null, baseMethod);
+ this._useSecondaryUV = useSecondaryUV;
+ this._lightMapTexture = lightMap;
+ this.blendMode = blendMode;
+ }
+ /**
+ * @inheritDoc
+ */
+ DiffuseLightMapMethod.prototype.iInitVO = function (shaderObject, methodVO) {
+ methodVO.needsSecondaryUV = this._useSecondaryUV;
+ methodVO.needsUV = !this._useSecondaryUV;
+ };
+ Object.defineProperty(DiffuseLightMapMethod.prototype, "blendMode", {
+ /**
+ * The blend mode with which the light map should be applied to the lighting result.
+ *
+ * @see DiffuseLightMapMethod.ADD
+ * @see DiffuseLightMapMethod.MULTIPLY
+ */
+ get: function () {
+ return this._blendMode;
+ },
+ set: function (value) {
+ if (value != DiffuseLightMapMethod.ADD && value != DiffuseLightMapMethod.MULTIPLY)
+ throw new Error("Unknown blendmode!");
+ if (this._blendMode == value)
+ return;
+ this._blendMode = value;
+ this.iInvalidateShaderProgram();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(DiffuseLightMapMethod.prototype, "lightMapTexture", {
+ /**
+ * The texture containing the light map data.
+ */
+ get: function () {
+ return this._lightMapTexture;
+ },
+ set: function (value) {
+ this._lightMapTexture = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ DiffuseLightMapMethod.prototype.iActivate = function (shaderObject, methodVO, stage) {
+ stage.context.activateTexture(methodVO.secondaryTexturesIndex, this._lightMapTexture);
+ _super.prototype.iActivate.call(this, shaderObject, methodVO, stage);
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseLightMapMethod.prototype.iGetFragmentPostLightingCode = function (shaderObject, methodVO, targetReg, registerCache, sharedRegisters) {
+ var code;
+ var lightMapReg = registerCache.getFreeTextureReg();
+ var temp = registerCache.getFreeFragmentVectorTemp();
+ methodVO.secondaryTexturesIndex = lightMapReg.index;
+ code = ShaderCompilerHelper.getTex2DSampleCode(temp, sharedRegisters, lightMapReg, this._lightMapTexture, shaderObject.useSmoothTextures, shaderObject.repeatTextures, shaderObject.useMipmapping, sharedRegisters.secondaryUVVarying);
+ switch (this._blendMode) {
+ case DiffuseLightMapMethod.MULTIPLY:
+ code += "mul " + this._pTotalLightColorReg + ", " + this._pTotalLightColorReg + ", " + temp + "\n";
+ break;
+ case DiffuseLightMapMethod.ADD:
+ code += "add " + this._pTotalLightColorReg + ", " + this._pTotalLightColorReg + ", " + temp + "\n";
+ break;
+ }
+ code += _super.prototype.iGetFragmentPostLightingCode.call(this, shaderObject, methodVO, targetReg, registerCache, sharedRegisters);
+ return code;
+ };
+ /**
+ * Indicates the light map should be multiplied with the calculated shading result.
+ * This can be used to add pre-calculated shadows or occlusion.
+ */
+ DiffuseLightMapMethod.MULTIPLY = "multiply";
+ /**
+ * Indicates the light map should be added into the calculated shading result.
+ * This can be used to add pre-calculated lighting or global illumination.
+ */
+ DiffuseLightMapMethod.ADD = "add";
+ return DiffuseLightMapMethod;
+})(DiffuseCompositeMethod);
+module.exports = DiffuseLightMapMethod;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["materials/methods/diffuselightmapmethod.ts"],"names":["DiffuseLightMapMethod","DiffuseLightMapMethod.constructor","DiffuseLightMapMethod.iInitVO","DiffuseLightMapMethod.blendMode","DiffuseLightMapMethod.lightMapTexture","DiffuseLightMapMethod.iActivate","DiffuseLightMapMethod.iGetFragmentPostLightingCode"],"mappings":"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","file":"materials/methods/DiffuseLightMapMethod.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Texture2DBase\t\t\t\t\t= require(\"awayjs-core/lib/textures/Texture2DBase\");\n\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport IContextStageGL\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/IContextStageGL\");\nimport MethodVO\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/MethodVO\");\nimport ShaderLightingObject\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderLightingObject\");\nimport ShaderRegisterCache\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterCache\");\nimport ShaderRegisterData\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterData\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\nimport DiffuseBasicMethod\t\t\t\t= require(\"awayjs-stagegl/lib/materials/methods/DiffuseBasicMethod\");\nimport ShaderCompilerHelper\t\t\t\t= require(\"awayjs-stagegl/lib/materials/utils/ShaderCompilerHelper\");\n\nimport DiffuseCompositeMethod\t\t\t= require(\"awayjs-renderergl/lib/materials/methods/DiffuseCompositeMethod\");\n\n/**\n * DiffuseLightMapMethod provides a diffuse shading method that uses a light map to modulate the calculated diffuse\n * lighting. It is different from EffectLightMapMethod in that the latter modulates the entire calculated pixel color, rather\n * than only the diffuse lighting value.\n */\nclass DiffuseLightMapMethod extends DiffuseCompositeMethod\n{\n\t/**\n\t * Indicates the light map should be multiplied with the calculated shading result.\n\t * This can be used to add pre-calculated shadows or occlusion.\n\t */\n\tpublic static MULTIPLY:string = \"multiply\";\n\n\t/**\n\t * Indicates the light map should be added into the calculated shading result.\n\t * This can be used to add pre-calculated lighting or global illumination.\n\t */\n\tpublic static ADD:string = \"add\";\n\n\tprivate _lightMapTexture:Texture2DBase;\n\tprivate _blendMode:string;\n\tprivate _useSecondaryUV:boolean;\n\n\t/**\n\t * Creates a new DiffuseLightMapMethod method.\n\t *\n\t * @param lightMap The texture containing the light map.\n\t * @param blendMode The blend mode with which the light map should be applied to the lighting result.\n\t * @param useSecondaryUV Indicates whether the secondary UV set should be used to map the light map.\n\t * @param baseMethod The diffuse method used to calculate the regular diffuse-based lighting.\n\t */\n\tconstructor(lightMap:Texture2DBase, blendMode:string = \"multiply\", useSecondaryUV:boolean = false, baseMethod:DiffuseBasicMethod = null)\n\t{\n\t\tsuper(null, baseMethod);\n\n\t\tthis._useSecondaryUV = useSecondaryUV;\n\t\tthis._lightMapTexture = lightMap;\n\t\tthis.blendMode = blendMode;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iInitVO(shaderObject:ShaderLightingObject, methodVO:MethodVO)\n\t{\n\t\tmethodVO.needsSecondaryUV = this._useSecondaryUV;\n\t\tmethodVO.needsUV = !this._useSecondaryUV;\n\t}\n\n\t/**\n\t * The blend mode with which the light map should be applied to the lighting result.\n\t *\n\t * @see DiffuseLightMapMethod.ADD\n\t * @see DiffuseLightMapMethod.MULTIPLY\n\t */\n\tpublic get blendMode():string\n\t{\n\t\treturn this._blendMode;\n\t}\n\n\tpublic set blendMode(value:string)\n\t{\n\t\tif (value != DiffuseLightMapMethod.ADD && value != DiffuseLightMapMethod.MULTIPLY)\n\t\t\tthrow new Error(\"Unknown blendmode!\");\n\n\t\tif (this._blendMode == value)\n\t\t\treturn;\n\n\t\tthis._blendMode = value;\n\n\t\tthis.iInvalidateShaderProgram();\n\t}\n\n\t/**\n\t * The texture containing the light map data.\n\t */\n\tpublic get lightMapTexture():Texture2DBase\n\t{\n\t\treturn this._lightMapTexture;\n\t}\n\n\tpublic set lightMapTexture(value:Texture2DBase)\n\t{\n\t\tthis._lightMapTexture = value;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iActivate(shaderObject:ShaderLightingObject, methodVO:MethodVO, stage:Stage)\n\t{\n\t\t(<IContextStageGL> stage.context).activateTexture(methodVO.secondaryTexturesIndex, this._lightMapTexture);\n\n\t\tsuper.iActivate(shaderObject, methodVO, stage);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iGetFragmentPostLightingCode(shaderObject:ShaderLightingObject, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\tvar code:string;\n\t\tvar lightMapReg:ShaderRegisterElement = registerCache.getFreeTextureReg();\n\t\tvar temp:ShaderRegisterElement = registerCache.getFreeFragmentVectorTemp();\n\t\tmethodVO.secondaryTexturesIndex = lightMapReg.index;\n\n\t\tcode = ShaderCompilerHelper.getTex2DSampleCode(temp, sharedRegisters, lightMapReg, this._lightMapTexture, shaderObject.useSmoothTextures, shaderObject.repeatTextures, shaderObject.useMipmapping, sharedRegisters.secondaryUVVarying);\n\n\t\tswitch (this._blendMode) {\n\t\t\tcase DiffuseLightMapMethod.MULTIPLY:\n\t\t\t\tcode += \"mul \" + this._pTotalLightColorReg + \", \" + this._pTotalLightColorReg + \", \" + temp + \"\\n\";\n\t\t\t\tbreak;\n\t\t\tcase DiffuseLightMapMethod.ADD:\n\t\t\t\tcode += \"add \" + this._pTotalLightColorReg + \", \" + this._pTotalLightColorReg + \", \" + temp + \"\\n\";\n\t\t\t\tbreak;\n\t\t}\n\n\t\tcode += super.iGetFragmentPostLightingCode(shaderObject, methodVO, targetReg, registerCache, sharedRegisters);\n\n\t\treturn code;\n\t}\n}\n\nexport = DiffuseLightMapMethod;"]}
\ No newline at end of file
diff --git a/lib/materials/methods/DiffuseLightMapMethod.ts b/lib/materials/methods/DiffuseLightMapMethod.ts
new file mode 100644
index 000000000..c58acc6fe
--- /dev/null
+++ b/lib/materials/methods/DiffuseLightMapMethod.ts
@@ -0,0 +1,138 @@
+import Texture2DBase = require("awayjs-core/lib/textures/Texture2DBase");
+
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import IContextStageGL = require("awayjs-stagegl/lib/core/stagegl/IContextStageGL");
+import MethodVO = require("awayjs-stagegl/lib/materials/compilation/MethodVO");
+import ShaderLightingObject = require("awayjs-stagegl/lib/materials/compilation/ShaderLightingObject");
+import ShaderRegisterCache = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterCache");
+import ShaderRegisterData = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterData");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+import DiffuseBasicMethod = require("awayjs-stagegl/lib/materials/methods/DiffuseBasicMethod");
+import ShaderCompilerHelper = require("awayjs-stagegl/lib/materials/utils/ShaderCompilerHelper");
+
+import DiffuseCompositeMethod = require("awayjs-renderergl/lib/materials/methods/DiffuseCompositeMethod");
+
+/**
+ * DiffuseLightMapMethod provides a diffuse shading method that uses a light map to modulate the calculated diffuse
+ * lighting. It is different from EffectLightMapMethod in that the latter modulates the entire calculated pixel color, rather
+ * than only the diffuse lighting value.
+ */
+class DiffuseLightMapMethod extends DiffuseCompositeMethod
+{
+ /**
+ * Indicates the light map should be multiplied with the calculated shading result.
+ * This can be used to add pre-calculated shadows or occlusion.
+ */
+ public static MULTIPLY:string = "multiply";
+
+ /**
+ * Indicates the light map should be added into the calculated shading result.
+ * This can be used to add pre-calculated lighting or global illumination.
+ */
+ public static ADD:string = "add";
+
+ private _lightMapTexture:Texture2DBase;
+ private _blendMode:string;
+ private _useSecondaryUV:boolean;
+
+ /**
+ * Creates a new DiffuseLightMapMethod method.
+ *
+ * @param lightMap The texture containing the light map.
+ * @param blendMode The blend mode with which the light map should be applied to the lighting result.
+ * @param useSecondaryUV Indicates whether the secondary UV set should be used to map the light map.
+ * @param baseMethod The diffuse method used to calculate the regular diffuse-based lighting.
+ */
+ constructor(lightMap:Texture2DBase, blendMode:string = "multiply", useSecondaryUV:boolean = false, baseMethod:DiffuseBasicMethod = null)
+ {
+ super(null, baseMethod);
+
+ this._useSecondaryUV = useSecondaryUV;
+ this._lightMapTexture = lightMap;
+ this.blendMode = blendMode;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iInitVO(shaderObject:ShaderLightingObject, methodVO:MethodVO)
+ {
+ methodVO.needsSecondaryUV = this._useSecondaryUV;
+ methodVO.needsUV = !this._useSecondaryUV;
+ }
+
+ /**
+ * The blend mode with which the light map should be applied to the lighting result.
+ *
+ * @see DiffuseLightMapMethod.ADD
+ * @see DiffuseLightMapMethod.MULTIPLY
+ */
+ public get blendMode():string
+ {
+ return this._blendMode;
+ }
+
+ public set blendMode(value:string)
+ {
+ if (value != DiffuseLightMapMethod.ADD && value != DiffuseLightMapMethod.MULTIPLY)
+ throw new Error("Unknown blendmode!");
+
+ if (this._blendMode == value)
+ return;
+
+ this._blendMode = value;
+
+ this.iInvalidateShaderProgram();
+ }
+
+ /**
+ * The texture containing the light map data.
+ */
+ public get lightMapTexture():Texture2DBase
+ {
+ return this._lightMapTexture;
+ }
+
+ public set lightMapTexture(value:Texture2DBase)
+ {
+ this._lightMapTexture = value;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iActivate(shaderObject:ShaderLightingObject, methodVO:MethodVO, stage:Stage)
+ {
+ ( stage.context).activateTexture(methodVO.secondaryTexturesIndex, this._lightMapTexture);
+
+ super.iActivate(shaderObject, methodVO, stage);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iGetFragmentPostLightingCode(shaderObject:ShaderLightingObject, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ var code:string;
+ var lightMapReg:ShaderRegisterElement = registerCache.getFreeTextureReg();
+ var temp:ShaderRegisterElement = registerCache.getFreeFragmentVectorTemp();
+ methodVO.secondaryTexturesIndex = lightMapReg.index;
+
+ code = ShaderCompilerHelper.getTex2DSampleCode(temp, sharedRegisters, lightMapReg, this._lightMapTexture, shaderObject.useSmoothTextures, shaderObject.repeatTextures, shaderObject.useMipmapping, sharedRegisters.secondaryUVVarying);
+
+ switch (this._blendMode) {
+ case DiffuseLightMapMethod.MULTIPLY:
+ code += "mul " + this._pTotalLightColorReg + ", " + this._pTotalLightColorReg + ", " + temp + "\n";
+ break;
+ case DiffuseLightMapMethod.ADD:
+ code += "add " + this._pTotalLightColorReg + ", " + this._pTotalLightColorReg + ", " + temp + "\n";
+ break;
+ }
+
+ code += super.iGetFragmentPostLightingCode(shaderObject, methodVO, targetReg, registerCache, sharedRegisters);
+
+ return code;
+ }
+}
+
+export = DiffuseLightMapMethod;
\ No newline at end of file
diff --git a/lib/materials/methods/DiffuseSubSurfaceMethod.js b/lib/materials/methods/DiffuseSubSurfaceMethod.js
new file mode 100755
index 000000000..f3920f96d
--- /dev/null
+++ b/lib/materials/methods/DiffuseSubSurfaceMethod.js
@@ -0,0 +1,211 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var DiffuseCompositeMethod = require("awayjs-renderergl/lib/materials/methods/DiffuseCompositeMethod");
+var SingleObjectDepthPass = require("awayjs-renderergl/lib/materials/passes/SingleObjectDepthPass");
+/**
+ * DiffuseSubSurfaceMethod provides a depth map-based diffuse shading method that mimics the scattering of
+ * light inside translucent surfaces. It allows light to shine through an object and to soften the diffuse shading.
+ * It can be used for candle wax, ice, skin, ...
+ */
+var DiffuseSubSurfaceMethod = (function (_super) {
+ __extends(DiffuseSubSurfaceMethod, _super);
+ /**
+ * Creates a new DiffuseSubSurfaceMethod
object.
+ *
+ * @param depthMapSize The size of the depth map used.
+ * @param depthMapOffset The amount by which the rendered object will be inflated, to prevent depth map rounding errors.
+ * @param baseMethod The diffuse method used to calculate the regular diffuse-based lighting.
+ */
+ function DiffuseSubSurfaceMethod(depthMapSize, depthMapOffset, baseMethod) {
+ var _this = this;
+ if (depthMapSize === void 0) { depthMapSize = 512; }
+ if (depthMapOffset === void 0) { depthMapOffset = 15; }
+ if (baseMethod === void 0) { baseMethod = null; }
+ _super.call(this, null, baseMethod);
+ this._translucency = 1;
+ this._scatterColor = 0xffffff;
+ this._scatterR = 1.0;
+ this._scatterG = 1.0;
+ this._scatterB = 1.0;
+ this.pBaseMethod._iModulateMethod = function (shaderObject, methodVO, targetReg, registerCache, sharedRegisters) { return _this.scatterLight(shaderObject, methodVO, targetReg, registerCache, sharedRegisters); };
+ this._passes = new Array();
+ this._depthPass = new SingleObjectDepthPass();
+ this._depthPass.textureSize = depthMapSize;
+ this._depthPass.polyOffset = depthMapOffset;
+ this._passes.push(this._depthPass);
+ this._scattering = 0.2;
+ this._translucency = 1;
+ }
+ /**
+ * @inheritDoc
+ */
+ DiffuseSubSurfaceMethod.prototype.iInitConstants = function (shaderObject, methodVO) {
+ _super.prototype.iInitConstants.call(this, shaderObject, methodVO);
+ var data = shaderObject.vertexConstantData;
+ var index = methodVO.secondaryVertexConstantsIndex;
+ data[index] = .5;
+ data[index + 1] = -.5;
+ data[index + 2] = 0;
+ data[index + 3] = 1;
+ data = shaderObject.fragmentConstantData;
+ index = methodVO.secondaryFragmentConstantsIndex;
+ data[index + 3] = 1.0;
+ data[index + 4] = 1.0;
+ data[index + 5] = 1 / 255;
+ data[index + 6] = 1 / 65025;
+ data[index + 7] = 1 / 16581375;
+ data[index + 10] = .5;
+ data[index + 11] = -.1;
+ };
+ DiffuseSubSurfaceMethod.prototype.iCleanCompilationData = function () {
+ _super.prototype.iCleanCompilationData.call(this);
+ this._lightProjVarying = null;
+ this._propReg = null;
+ this._lightColorReg = null;
+ this._colorReg = null;
+ this._decReg = null;
+ this._targetReg = null;
+ };
+ Object.defineProperty(DiffuseSubSurfaceMethod.prototype, "scattering", {
+ /**
+ * The amount by which the light scatters. It can be used to set the translucent surface's thickness. Use low
+ * values for skin.
+ */
+ get: function () {
+ return this._scattering;
+ },
+ set: function (value) {
+ this._scattering = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(DiffuseSubSurfaceMethod.prototype, "translucency", {
+ /**
+ * The translucency of the object.
+ */
+ get: function () {
+ return this._translucency;
+ },
+ set: function (value) {
+ this._translucency = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(DiffuseSubSurfaceMethod.prototype, "scatterColor", {
+ /**
+ * The colour of the "insides" of the object, ie: the colour the light becomes after leaving the object.
+ */
+ get: function () {
+ return this._scatterColor;
+ },
+ set: function (scatterColor /*uint*/) {
+ this._scatterColor = scatterColor;
+ this._scatterR = ((scatterColor >> 16) & 0xff) / 0xff;
+ this._scatterG = ((scatterColor >> 8) & 0xff) / 0xff;
+ this._scatterB = (scatterColor & 0xff) / 0xff;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ DiffuseSubSurfaceMethod.prototype.iGetVertexCode = function (shaderObject, methodVO, registerCache, sharedRegisters) {
+ var code = _super.prototype.iGetVertexCode.call(this, shaderObject, methodVO, registerCache, sharedRegisters);
+ var lightProjection;
+ var toTexRegister;
+ var temp = registerCache.getFreeVertexVectorTemp();
+ toTexRegister = registerCache.getFreeVertexConstant();
+ methodVO.secondaryVertexConstantsIndex = toTexRegister.index * 4;
+ this._lightProjVarying = registerCache.getFreeVarying();
+ lightProjection = registerCache.getFreeVertexConstant();
+ registerCache.getFreeVertexConstant();
+ registerCache.getFreeVertexConstant();
+ registerCache.getFreeVertexConstant();
+ code += "m44 " + temp + ", vt0, " + lightProjection + "\n" + "div " + temp + ".xyz, " + temp + ".xyz, " + temp + ".w\n" + "mul " + temp + ".xy, " + temp + ".xy, " + toTexRegister + ".xy\n" + "add " + temp + ".xy, " + temp + ".xy, " + toTexRegister + ".xx\n" + "mov " + this._lightProjVarying + ".xyz, " + temp + ".xyz\n" + "mov " + this._lightProjVarying + ".w, va0.w\n";
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseSubSurfaceMethod.prototype.iGetFragmentPreLightingCode = function (shaderObject, methodVO, registerCache, sharedRegisters) {
+ this._colorReg = registerCache.getFreeFragmentConstant();
+ this._decReg = registerCache.getFreeFragmentConstant();
+ this._propReg = registerCache.getFreeFragmentConstant();
+ methodVO.secondaryFragmentConstantsIndex = this._colorReg.index * 4;
+ return _super.prototype.iGetFragmentPreLightingCode.call(this, shaderObject, methodVO, registerCache, sharedRegisters);
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseSubSurfaceMethod.prototype.iGetFragmentCodePerLight = function (shaderObject, methodVO, lightDirReg, lightColReg, registerCache, sharedRegisters) {
+ this._pIsFirstLight = true;
+ this._lightColorReg = lightColReg;
+ return _super.prototype.iGetFragmentCodePerLight.call(this, shaderObject, methodVO, lightDirReg, lightColReg, registerCache, sharedRegisters);
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseSubSurfaceMethod.prototype.iGetFragmentPostLightingCode = function (shaderObject, methodVO, targetReg, registerCache, sharedRegisters) {
+ var code = _super.prototype.iGetFragmentPostLightingCode.call(this, shaderObject, methodVO, targetReg, registerCache, sharedRegisters);
+ var temp = registerCache.getFreeFragmentVectorTemp();
+ code += "mul " + temp + ".xyz, " + this._lightColorReg + ".xyz, " + this._targetReg + ".w\n" + "mul " + temp + ".xyz, " + temp + ".xyz, " + this._colorReg + ".xyz\n" + "add " + targetReg + ".xyz, " + targetReg + ".xyz, " + temp + ".xyz\n";
+ if (this._targetReg != sharedRegisters.viewDirFragment)
+ registerCache.removeFragmentTempUsage(targetReg);
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseSubSurfaceMethod.prototype.iActivate = function (shaderObject, methodVO, stage) {
+ _super.prototype.iActivate.call(this, shaderObject, methodVO, stage);
+ var index = methodVO.secondaryFragmentConstantsIndex;
+ var data = shaderObject.fragmentConstantData;
+ data[index] = this._scatterR;
+ data[index + 1] = this._scatterG;
+ data[index + 2] = this._scatterB;
+ data[index + 8] = this._scattering;
+ data[index + 9] = this._translucency;
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseSubSurfaceMethod.prototype.iSetRenderState = function (shaderObject, methodVO, renderable, stage, camera) {
+ stage.context.activateTexture(methodVO.secondaryTexturesIndex, this._depthPass._iGetDepthMap(renderable));
+ this._depthPass._iGetProjection(renderable).copyRawDataTo(shaderObject.vertexConstantData, methodVO.secondaryVertexConstantsIndex + 4, true);
+ };
+ /**
+ * Generates the code for this method
+ */
+ DiffuseSubSurfaceMethod.prototype.scatterLight = function (shaderObject, methodVO, targetReg, registerCache, sharedRegisters) {
+ // only scatter first light
+ if (!this._pIsFirstLight)
+ return "";
+ this._pIsFirstLight = false;
+ var code = "";
+ var depthReg = registerCache.getFreeTextureReg();
+ if (sharedRegisters.viewDirFragment) {
+ this._targetReg = sharedRegisters.viewDirFragment;
+ }
+ else {
+ this._targetReg = registerCache.getFreeFragmentVectorTemp();
+ registerCache.addFragmentTempUsages(this._targetReg, 1);
+ }
+ methodVO.secondaryTexturesIndex = depthReg.index;
+ var temp = registerCache.getFreeFragmentVectorTemp();
+ code += "tex " + temp + ", " + this._lightProjVarying + ", " + depthReg + " <2d,nearest,clamp>\n" + "dp4 " + targetReg + ".z, " + temp + ", " + this._decReg + "\n";
+ // currentDistanceToLight - closestDistanceToLight
+ code += "sub " + targetReg + ".z, " + this._lightProjVarying + ".z, " + targetReg + ".z\n" + "sub " + targetReg + ".z, " + this._propReg + ".x, " + targetReg + ".z\n" + "mul " + targetReg + ".z, " + this._propReg + ".y, " + targetReg + ".z\n" + "sat " + targetReg + ".z, " + targetReg + ".z\n" + "neg " + targetReg + ".y, " + targetReg + ".x\n" + "mul " + targetReg + ".y, " + targetReg + ".y, " + this._propReg + ".z\n" + "add " + targetReg + ".y, " + targetReg + ".y, " + this._propReg + ".z\n" + "mul " + this._targetReg + ".w, " + targetReg + ".z, " + targetReg + ".y\n" + "sub " + targetReg + ".y, " + this._colorReg + ".w, " + this._targetReg + ".w\n" + "mul " + targetReg + ".w, " + targetReg + ".w, " + targetReg + ".y\n";
+ return code;
+ };
+ return DiffuseSubSurfaceMethod;
+})(DiffuseCompositeMethod);
+module.exports = DiffuseSubSurfaceMethod;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["materials/methods/diffusesubsurfacemethod.ts"],"names":["DiffuseSubSurfaceMethod","DiffuseSubSurfaceMethod.constructor","DiffuseSubSurfaceMethod.iInitConstants","DiffuseSubSurfaceMethod.iCleanCompilationData","DiffuseSubSurfaceMethod.scattering","DiffuseSubSurfaceMethod.translucency","DiffuseSubSurfaceMethod.scatterColor","DiffuseSubSurfaceMethod.iGetVertexCode","DiffuseSubSurfaceMethod.iGetFragmentPreLightingCode","DiffuseSubSurfaceMethod.iGetFragmentCodePerLight","DiffuseSubSurfaceMethod.iGetFragmentPostLightingCode","DiffuseSubSurfaceMethod.iActivate","DiffuseSubSurfaceMethod.iSetRenderState","DiffuseSubSurfaceMethod.scatterLight"],"mappings":"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","file":"materials/methods/DiffuseSubSurfaceMethod.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Camera\t\t\t\t\t\t\t= require(\"awayjs-core/lib/entities/Camera\");\n\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport RenderableBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/pool/RenderableBase\");\nimport IContextStageGL\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/IContextStageGL\");\nimport MethodVO\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/MethodVO\");\nimport ShaderLightingObject\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderLightingObject\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterCache\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterCache\");\nimport ShaderRegisterData\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterData\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\nimport DiffuseBasicMethod\t\t\t\t= require(\"awayjs-stagegl/lib/materials/methods/DiffuseBasicMethod\");\nimport MaterialPassBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/passes/MaterialPassBase\");\n\nimport DiffuseCompositeMethod\t\t\t= require(\"awayjs-renderergl/lib/materials/methods/DiffuseCompositeMethod\");\nimport SingleObjectDepthPass\t\t\t= require(\"awayjs-renderergl/lib/materials/passes/SingleObjectDepthPass\");\n\n/**\n * DiffuseSubSurfaceMethod provides a depth map-based diffuse shading method that mimics the scattering of\n * light inside translucent surfaces. It allows light to shine through an object and to soften the diffuse shading.\n * It can be used for candle wax, ice, skin, ...\n */\nclass DiffuseSubSurfaceMethod extends DiffuseCompositeMethod\n{\n\tprivate _depthPass:SingleObjectDepthPass;\n\tprivate _lightProjVarying:ShaderRegisterElement;\n\tprivate _propReg:ShaderRegisterElement;\n\tprivate _scattering:number;\n\tprivate _translucency:number = 1;\n\tprivate _lightColorReg:ShaderRegisterElement;\n\tprivate _scatterColor:number /*uint*/ = 0xffffff;\n\tprivate _colorReg:ShaderRegisterElement;\n\tprivate _decReg:ShaderRegisterElement;\n\tprivate _scatterR:number = 1.0;\n\tprivate _scatterG:number = 1.0;\n\tprivate _scatterB:number = 1.0;\n\tprivate _targetReg:ShaderRegisterElement;\n\t\n\t/**\n\t * Creates a new <code>DiffuseSubSurfaceMethod</code> object.\n\t *\n\t * @param depthMapSize The size of the depth map used.\n\t * @param depthMapOffset The amount by which the rendered object will be inflated, to prevent depth map rounding errors.\n\t * @param baseMethod The diffuse method used to calculate the regular diffuse-based lighting.\n\t */\n\tconstructor(depthMapSize:number /*int*/ = 512, depthMapOffset:number = 15, baseMethod:DiffuseBasicMethod = null)\n\t{\n\t\tsuper(null, baseMethod);\n\n\t\tthis.pBaseMethod._iModulateMethod = (shaderObject:ShaderObjectBase, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData) => this.scatterLight(shaderObject, methodVO, targetReg, registerCache, sharedRegisters);\n\n\t\tthis._passes = new Array<MaterialPassBase>();\n\t\tthis._depthPass = new SingleObjectDepthPass();\n\t\tthis._depthPass.textureSize = depthMapSize;\n\t\tthis._depthPass.polyOffset = depthMapOffset;\n\t\tthis._passes.push(this._depthPass);\n\t\tthis._scattering = 0.2;\n\t\tthis._translucency = 1;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iInitConstants(shaderObject:ShaderLightingObject, methodVO:MethodVO)\n\t{\n\t\tsuper.iInitConstants(shaderObject, methodVO);\n\n\t\tvar data:Array<number> = shaderObject.vertexConstantData;\n\t\tvar index:number /*int*/ = methodVO.secondaryVertexConstantsIndex;\n\t\tdata[index] = .5;\n\t\tdata[index + 1] = -.5;\n\t\tdata[index + 2] = 0;\n\t\tdata[index + 3] = 1;\n\t\t\n\t\tdata = shaderObject.fragmentConstantData;\n\t\tindex = methodVO.secondaryFragmentConstantsIndex;\n\t\tdata[index + 3] = 1.0;\n\t\tdata[index + 4] = 1.0;\n\t\tdata[index + 5] = 1/255;\n\t\tdata[index + 6] = 1/65025;\n\t\tdata[index + 7] = 1/16581375;\n\t\tdata[index + 10] = .5;\n\t\tdata[index + 11] = -.1;\n\t}\n\t\n\tpublic iCleanCompilationData()\n\t{\n\t\tsuper.iCleanCompilationData();\n\n\t\tthis._lightProjVarying = null;\n\t\tthis._propReg = null;\n\t\tthis._lightColorReg = null;\n\t\tthis._colorReg = null;\n\t\tthis._decReg = null;\n\t\tthis._targetReg = null;\n\t}\n\t\n\t/**\n\t * The amount by which the light scatters. It can be used to set the translucent surface's thickness. Use low\n\t * values for skin.\n\t */\n\tpublic get scattering():number\n\t{\n\t\treturn this._scattering;\n\t}\n\t\n\tpublic set scattering(value:number)\n\t{\n\t\tthis._scattering = value;\n\t}\n\t\n\t/**\n\t * The translucency of the object.\n\t */\n\tpublic get translucency():number\n\t{\n\t\treturn this._translucency;\n\t}\n\t\n\tpublic set translucency(value:number)\n\t{\n\t\tthis._translucency = value;\n\t}\n\t\n\t/**\n\t * The colour of the \"insides\" of the object, ie: the colour the light becomes after leaving the object.\n\t */\n\tpublic get scatterColor():number /*uint*/\n\t{\n\t\treturn this._scatterColor;\n\t}\n\t\n\tpublic set scatterColor(scatterColor:number /*uint*/)\n\t{\n\t\tthis._scatterColor = scatterColor;\n\t\tthis._scatterR = ((scatterColor >> 16) & 0xff)/0xff;\n\t\tthis._scatterG = ((scatterColor >> 8) & 0xff)/0xff;\n\t\tthis._scatterB = (scatterColor & 0xff)/0xff;\n\t}\n\t\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iGetVertexCode(shaderObject:ShaderObjectBase, methodVO:MethodVO, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\tvar code:string = super.iGetVertexCode(shaderObject, methodVO, registerCache, sharedRegisters);\n\t\tvar lightProjection:ShaderRegisterElement;\n\t\tvar toTexRegister:ShaderRegisterElement;\n\t\tvar temp:ShaderRegisterElement = registerCache.getFreeVertexVectorTemp();\n\t\t\n\t\ttoTexRegister = registerCache.getFreeVertexConstant();\n\t\tmethodVO.secondaryVertexConstantsIndex = toTexRegister.index*4;\n\n\t\tthis._lightProjVarying = registerCache.getFreeVarying();\n\t\tlightProjection = registerCache.getFreeVertexConstant();\n\t\tregisterCache.getFreeVertexConstant();\n\t\tregisterCache.getFreeVertexConstant();\n\t\tregisterCache.getFreeVertexConstant();\n\t\t\n\t\tcode += \"m44 \" + temp + \", vt0, \" + lightProjection + \"\\n\" +\n\t\t\t\"div \" + temp + \".xyz, \" + temp + \".xyz, \" + temp + \".w\\n\" +\n\t\t\t\"mul \" + temp + \".xy, \" + temp + \".xy, \" + toTexRegister + \".xy\\n\" +\n\t\t\t\"add \" + temp + \".xy, \" + temp + \".xy, \" + toTexRegister + \".xx\\n\" +\n\t\t\t\"mov \" + this._lightProjVarying + \".xyz, \" + temp + \".xyz\\n\" +\n\t\t\t\"mov \" + this._lightProjVarying + \".w, va0.w\\n\";\n\t\t\n\t\treturn code;\n\t}\n\t\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iGetFragmentPreLightingCode(shaderObject:ShaderLightingObject, methodVO:MethodVO, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\tthis._colorReg = registerCache.getFreeFragmentConstant();\n\t\tthis._decReg = registerCache.getFreeFragmentConstant();\n\t\tthis._propReg = registerCache.getFreeFragmentConstant();\n\t\tmethodVO.secondaryFragmentConstantsIndex = this._colorReg.index*4;\n\t\t\n\t\treturn super.iGetFragmentPreLightingCode(shaderObject, methodVO, registerCache, sharedRegisters);\n\t}\n\t\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iGetFragmentCodePerLight(shaderObject:ShaderLightingObject, methodVO:MethodVO, lightDirReg:ShaderRegisterElement, lightColReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\tthis._pIsFirstLight = true;\n\t\tthis._lightColorReg = lightColReg;\n\t\treturn super.iGetFragmentCodePerLight(shaderObject, methodVO, lightDirReg, lightColReg, registerCache, sharedRegisters);\n\t}\n\t\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iGetFragmentPostLightingCode(shaderObject:ShaderLightingObject, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\tvar code:string = super.iGetFragmentPostLightingCode(shaderObject, methodVO, targetReg, registerCache, sharedRegisters);\n\t\tvar temp:ShaderRegisterElement = registerCache.getFreeFragmentVectorTemp();\n\t\t\n\t\tcode += \"mul \" + temp + \".xyz, \" + this._lightColorReg + \".xyz, \" + this._targetReg + \".w\\n\" +\n\t\t\t\"mul \" + temp + \".xyz, \" + temp + \".xyz, \" + this._colorReg + \".xyz\\n\" +\n\t\t\t\"add \" + targetReg + \".xyz, \" + targetReg + \".xyz, \" + temp + \".xyz\\n\";\n\t\t\n\t\tif (this._targetReg != sharedRegisters.viewDirFragment)\n\t\t\tregisterCache.removeFragmentTempUsage(targetReg);\n\t\t\n\t\treturn code;\n\t}\n\t\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iActivate(shaderObject:ShaderLightingObject, methodVO:MethodVO, stage:Stage)\n\t{\n\t\tsuper.iActivate(shaderObject, methodVO, stage);\n\t\t\n\t\tvar index:number /*int*/ = methodVO.secondaryFragmentConstantsIndex;\n\t\tvar data:Array<number> = shaderObject.fragmentConstantData;\n\t\tdata[index] = this._scatterR;\n\t\tdata[index + 1] = this._scatterG;\n\t\tdata[index + 2] = this._scatterB;\n\t\tdata[index + 8] = this._scattering;\n\t\tdata[index + 9] = this._translucency;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iSetRenderState(shaderObject:ShaderObjectBase, methodVO:MethodVO, renderable:RenderableBase, stage:Stage, camera:Camera)\n\t{\n\t\t(<IContextStageGL> stage.context).activateTexture(methodVO.secondaryTexturesIndex, this._depthPass._iGetDepthMap(renderable));\n\n\t\tthis._depthPass._iGetProjection(renderable).copyRawDataTo(shaderObject.vertexConstantData, methodVO.secondaryVertexConstantsIndex + 4, true);\n\t}\n\t\n\t/**\n\t * Generates the code for this method\n\t */\n\tprivate scatterLight(shaderObject:ShaderObjectBase, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\t// only scatter first light\n\t\tif (!this._pIsFirstLight)\n\t\t\treturn \"\";\n\n\t\tthis._pIsFirstLight = false;\n\n\t\tvar code:string = \"\";\n\t\tvar depthReg:ShaderRegisterElement = registerCache.getFreeTextureReg();\n\n\t\tif (sharedRegisters.viewDirFragment) {\n\t\t\tthis._targetReg = sharedRegisters.viewDirFragment;\n\t\t} else {\n\t\t\tthis._targetReg = registerCache.getFreeFragmentVectorTemp();\n\t\t\tregisterCache.addFragmentTempUsages(this._targetReg, 1);\n\t\t}\n\n\t\tmethodVO.secondaryTexturesIndex = depthReg.index;\n\t\t\n\t\tvar temp:ShaderRegisterElement = registerCache.getFreeFragmentVectorTemp();\n\t\tcode += \"tex \" + temp + \", \" + this._lightProjVarying + \", \" + depthReg + \" <2d,nearest,clamp>\\n\" +\n\t\t\t// reencode RGBA\n\t\t\t\"dp4 \" + targetReg + \".z, \" + temp + \", \" + this._decReg + \"\\n\";\n\t\t// currentDistanceToLight - closestDistanceToLight\n\t\tcode += \"sub \" + targetReg + \".z, \" + this._lightProjVarying + \".z, \" + targetReg + \".z\\n\" +\n\t\t\t\n\t\t\t\"sub \" + targetReg + \".z, \" + this._propReg + \".x, \" + targetReg + \".z\\n\" +\n\t\t\t\"mul \" + targetReg + \".z, \" + this._propReg + \".y, \" + targetReg + \".z\\n\" +\n\t\t\t\"sat \" + targetReg + \".z, \" + targetReg + \".z\\n\" +\n\t\t\t\n\t\t\t// targetReg.x contains dot(lightDir, normal)\n\t\t\t// modulate according to incident light angle (scatter = scatter*(-.5*dot(light, normal) + .5)\n\t\t\t\"neg \" + targetReg + \".y, \" + targetReg + \".x\\n\" +\n\t\t\t\"mul \" + targetReg + \".y, \" + targetReg + \".y, \" + this._propReg + \".z\\n\" +\n\t\t\t\"add \" + targetReg + \".y, \" + targetReg + \".y, \" + this._propReg + \".z\\n\" +\n\t\t\t\"mul \" + this._targetReg + \".w, \" + targetReg + \".z, \" + targetReg + \".y\\n\" +\n\t\t\t\n\t\t\t// blend diffuse: d' = (1-s)*d + s*1\n\t\t\t\"sub \" + targetReg + \".y, \" + this._colorReg + \".w, \" + this._targetReg + \".w\\n\" +\n\t\t\t\"mul \" + targetReg + \".w, \" + targetReg + \".w, \" + targetReg + \".y\\n\";\n\t\t\n\t\treturn code;\n\t}\n}\n\nexport = DiffuseSubSurfaceMethod;"]}
\ No newline at end of file
diff --git a/lib/materials/methods/DiffuseSubSurfaceMethod.ts b/lib/materials/methods/DiffuseSubSurfaceMethod.ts
new file mode 100644
index 000000000..6b0622b9a
--- /dev/null
+++ b/lib/materials/methods/DiffuseSubSurfaceMethod.ts
@@ -0,0 +1,286 @@
+import Camera = require("awayjs-core/lib/entities/Camera");
+
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import RenderableBase = require("awayjs-stagegl/lib/core/pool/RenderableBase");
+import IContextStageGL = require("awayjs-stagegl/lib/core/stagegl/IContextStageGL");
+import MethodVO = require("awayjs-stagegl/lib/materials/compilation/MethodVO");
+import ShaderLightingObject = require("awayjs-stagegl/lib/materials/compilation/ShaderLightingObject");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterCache = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterCache");
+import ShaderRegisterData = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterData");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+import DiffuseBasicMethod = require("awayjs-stagegl/lib/materials/methods/DiffuseBasicMethod");
+import MaterialPassBase = require("awayjs-stagegl/lib/materials/passes/MaterialPassBase");
+
+import DiffuseCompositeMethod = require("awayjs-renderergl/lib/materials/methods/DiffuseCompositeMethod");
+import SingleObjectDepthPass = require("awayjs-renderergl/lib/materials/passes/SingleObjectDepthPass");
+
+/**
+ * DiffuseSubSurfaceMethod provides a depth map-based diffuse shading method that mimics the scattering of
+ * light inside translucent surfaces. It allows light to shine through an object and to soften the diffuse shading.
+ * It can be used for candle wax, ice, skin, ...
+ */
+class DiffuseSubSurfaceMethod extends DiffuseCompositeMethod
+{
+ private _depthPass:SingleObjectDepthPass;
+ private _lightProjVarying:ShaderRegisterElement;
+ private _propReg:ShaderRegisterElement;
+ private _scattering:number;
+ private _translucency:number = 1;
+ private _lightColorReg:ShaderRegisterElement;
+ private _scatterColor:number /*uint*/ = 0xffffff;
+ private _colorReg:ShaderRegisterElement;
+ private _decReg:ShaderRegisterElement;
+ private _scatterR:number = 1.0;
+ private _scatterG:number = 1.0;
+ private _scatterB:number = 1.0;
+ private _targetReg:ShaderRegisterElement;
+
+ /**
+ * Creates a new DiffuseSubSurfaceMethod
object.
+ *
+ * @param depthMapSize The size of the depth map used.
+ * @param depthMapOffset The amount by which the rendered object will be inflated, to prevent depth map rounding errors.
+ * @param baseMethod The diffuse method used to calculate the regular diffuse-based lighting.
+ */
+ constructor(depthMapSize:number /*int*/ = 512, depthMapOffset:number = 15, baseMethod:DiffuseBasicMethod = null)
+ {
+ super(null, baseMethod);
+
+ this.pBaseMethod._iModulateMethod = (shaderObject:ShaderObjectBase, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData) => this.scatterLight(shaderObject, methodVO, targetReg, registerCache, sharedRegisters);
+
+ this._passes = new Array();
+ this._depthPass = new SingleObjectDepthPass();
+ this._depthPass.textureSize = depthMapSize;
+ this._depthPass.polyOffset = depthMapOffset;
+ this._passes.push(this._depthPass);
+ this._scattering = 0.2;
+ this._translucency = 1;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iInitConstants(shaderObject:ShaderLightingObject, methodVO:MethodVO)
+ {
+ super.iInitConstants(shaderObject, methodVO);
+
+ var data:Array = shaderObject.vertexConstantData;
+ var index:number /*int*/ = methodVO.secondaryVertexConstantsIndex;
+ data[index] = .5;
+ data[index + 1] = -.5;
+ data[index + 2] = 0;
+ data[index + 3] = 1;
+
+ data = shaderObject.fragmentConstantData;
+ index = methodVO.secondaryFragmentConstantsIndex;
+ data[index + 3] = 1.0;
+ data[index + 4] = 1.0;
+ data[index + 5] = 1/255;
+ data[index + 6] = 1/65025;
+ data[index + 7] = 1/16581375;
+ data[index + 10] = .5;
+ data[index + 11] = -.1;
+ }
+
+ public iCleanCompilationData()
+ {
+ super.iCleanCompilationData();
+
+ this._lightProjVarying = null;
+ this._propReg = null;
+ this._lightColorReg = null;
+ this._colorReg = null;
+ this._decReg = null;
+ this._targetReg = null;
+ }
+
+ /**
+ * The amount by which the light scatters. It can be used to set the translucent surface's thickness. Use low
+ * values for skin.
+ */
+ public get scattering():number
+ {
+ return this._scattering;
+ }
+
+ public set scattering(value:number)
+ {
+ this._scattering = value;
+ }
+
+ /**
+ * The translucency of the object.
+ */
+ public get translucency():number
+ {
+ return this._translucency;
+ }
+
+ public set translucency(value:number)
+ {
+ this._translucency = value;
+ }
+
+ /**
+ * The colour of the "insides" of the object, ie: the colour the light becomes after leaving the object.
+ */
+ public get scatterColor():number /*uint*/
+ {
+ return this._scatterColor;
+ }
+
+ public set scatterColor(scatterColor:number /*uint*/)
+ {
+ this._scatterColor = scatterColor;
+ this._scatterR = ((scatterColor >> 16) & 0xff)/0xff;
+ this._scatterG = ((scatterColor >> 8) & 0xff)/0xff;
+ this._scatterB = (scatterColor & 0xff)/0xff;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iGetVertexCode(shaderObject:ShaderObjectBase, methodVO:MethodVO, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ var code:string = super.iGetVertexCode(shaderObject, methodVO, registerCache, sharedRegisters);
+ var lightProjection:ShaderRegisterElement;
+ var toTexRegister:ShaderRegisterElement;
+ var temp:ShaderRegisterElement = registerCache.getFreeVertexVectorTemp();
+
+ toTexRegister = registerCache.getFreeVertexConstant();
+ methodVO.secondaryVertexConstantsIndex = toTexRegister.index*4;
+
+ this._lightProjVarying = registerCache.getFreeVarying();
+ lightProjection = registerCache.getFreeVertexConstant();
+ registerCache.getFreeVertexConstant();
+ registerCache.getFreeVertexConstant();
+ registerCache.getFreeVertexConstant();
+
+ code += "m44 " + temp + ", vt0, " + lightProjection + "\n" +
+ "div " + temp + ".xyz, " + temp + ".xyz, " + temp + ".w\n" +
+ "mul " + temp + ".xy, " + temp + ".xy, " + toTexRegister + ".xy\n" +
+ "add " + temp + ".xy, " + temp + ".xy, " + toTexRegister + ".xx\n" +
+ "mov " + this._lightProjVarying + ".xyz, " + temp + ".xyz\n" +
+ "mov " + this._lightProjVarying + ".w, va0.w\n";
+
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iGetFragmentPreLightingCode(shaderObject:ShaderLightingObject, methodVO:MethodVO, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ this._colorReg = registerCache.getFreeFragmentConstant();
+ this._decReg = registerCache.getFreeFragmentConstant();
+ this._propReg = registerCache.getFreeFragmentConstant();
+ methodVO.secondaryFragmentConstantsIndex = this._colorReg.index*4;
+
+ return super.iGetFragmentPreLightingCode(shaderObject, methodVO, registerCache, sharedRegisters);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iGetFragmentCodePerLight(shaderObject:ShaderLightingObject, methodVO:MethodVO, lightDirReg:ShaderRegisterElement, lightColReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ this._pIsFirstLight = true;
+ this._lightColorReg = lightColReg;
+ return super.iGetFragmentCodePerLight(shaderObject, methodVO, lightDirReg, lightColReg, registerCache, sharedRegisters);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iGetFragmentPostLightingCode(shaderObject:ShaderLightingObject, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ var code:string = super.iGetFragmentPostLightingCode(shaderObject, methodVO, targetReg, registerCache, sharedRegisters);
+ var temp:ShaderRegisterElement = registerCache.getFreeFragmentVectorTemp();
+
+ code += "mul " + temp + ".xyz, " + this._lightColorReg + ".xyz, " + this._targetReg + ".w\n" +
+ "mul " + temp + ".xyz, " + temp + ".xyz, " + this._colorReg + ".xyz\n" +
+ "add " + targetReg + ".xyz, " + targetReg + ".xyz, " + temp + ".xyz\n";
+
+ if (this._targetReg != sharedRegisters.viewDirFragment)
+ registerCache.removeFragmentTempUsage(targetReg);
+
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iActivate(shaderObject:ShaderLightingObject, methodVO:MethodVO, stage:Stage)
+ {
+ super.iActivate(shaderObject, methodVO, stage);
+
+ var index:number /*int*/ = methodVO.secondaryFragmentConstantsIndex;
+ var data:Array = shaderObject.fragmentConstantData;
+ data[index] = this._scatterR;
+ data[index + 1] = this._scatterG;
+ data[index + 2] = this._scatterB;
+ data[index + 8] = this._scattering;
+ data[index + 9] = this._translucency;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iSetRenderState(shaderObject:ShaderObjectBase, methodVO:MethodVO, renderable:RenderableBase, stage:Stage, camera:Camera)
+ {
+ ( stage.context).activateTexture(methodVO.secondaryTexturesIndex, this._depthPass._iGetDepthMap(renderable));
+
+ this._depthPass._iGetProjection(renderable).copyRawDataTo(shaderObject.vertexConstantData, methodVO.secondaryVertexConstantsIndex + 4, true);
+ }
+
+ /**
+ * Generates the code for this method
+ */
+ private scatterLight(shaderObject:ShaderObjectBase, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ // only scatter first light
+ if (!this._pIsFirstLight)
+ return "";
+
+ this._pIsFirstLight = false;
+
+ var code:string = "";
+ var depthReg:ShaderRegisterElement = registerCache.getFreeTextureReg();
+
+ if (sharedRegisters.viewDirFragment) {
+ this._targetReg = sharedRegisters.viewDirFragment;
+ } else {
+ this._targetReg = registerCache.getFreeFragmentVectorTemp();
+ registerCache.addFragmentTempUsages(this._targetReg, 1);
+ }
+
+ methodVO.secondaryTexturesIndex = depthReg.index;
+
+ var temp:ShaderRegisterElement = registerCache.getFreeFragmentVectorTemp();
+ code += "tex " + temp + ", " + this._lightProjVarying + ", " + depthReg + " <2d,nearest,clamp>\n" +
+ // reencode RGBA
+ "dp4 " + targetReg + ".z, " + temp + ", " + this._decReg + "\n";
+ // currentDistanceToLight - closestDistanceToLight
+ code += "sub " + targetReg + ".z, " + this._lightProjVarying + ".z, " + targetReg + ".z\n" +
+
+ "sub " + targetReg + ".z, " + this._propReg + ".x, " + targetReg + ".z\n" +
+ "mul " + targetReg + ".z, " + this._propReg + ".y, " + targetReg + ".z\n" +
+ "sat " + targetReg + ".z, " + targetReg + ".z\n" +
+
+ // targetReg.x contains dot(lightDir, normal)
+ // modulate according to incident light angle (scatter = scatter*(-.5*dot(light, normal) + .5)
+ "neg " + targetReg + ".y, " + targetReg + ".x\n" +
+ "mul " + targetReg + ".y, " + targetReg + ".y, " + this._propReg + ".z\n" +
+ "add " + targetReg + ".y, " + targetReg + ".y, " + this._propReg + ".z\n" +
+ "mul " + this._targetReg + ".w, " + targetReg + ".z, " + targetReg + ".y\n" +
+
+ // blend diffuse: d' = (1-s)*d + s*1
+ "sub " + targetReg + ".y, " + this._colorReg + ".w, " + this._targetReg + ".w\n" +
+ "mul " + targetReg + ".w, " + targetReg + ".w, " + targetReg + ".y\n";
+
+ return code;
+ }
+}
+
+export = DiffuseSubSurfaceMethod;
\ No newline at end of file
diff --git a/lib/materials/methods/DiffuseWrapMethod.js b/lib/materials/methods/DiffuseWrapMethod.js
new file mode 100755
index 000000000..4dd9ee90f
--- /dev/null
+++ b/lib/materials/methods/DiffuseWrapMethod.js
@@ -0,0 +1,93 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var DiffuseBasicMethod = require("awayjs-stagegl/lib/materials/methods/DiffuseBasicMethod");
+/**
+ * DiffuseWrapMethod is an alternative to DiffuseBasicMethod in which the light is allowed to be "wrapped around" the normally dark area, to some extent.
+ * It can be used as a crude approximation to Oren-Nayar or simple subsurface scattering.
+ */
+var DiffuseWrapMethod = (function (_super) {
+ __extends(DiffuseWrapMethod, _super);
+ /**
+ * Creates a new DiffuseWrapMethod object.
+ * @param wrapFactor A factor to indicate the amount by which the light is allowed to wrap
+ */
+ function DiffuseWrapMethod(wrapFactor) {
+ if (wrapFactor === void 0) { wrapFactor = .5; }
+ _super.call(this);
+ this.wrapFactor = wrapFactor;
+ }
+ /**
+ * @inheritDoc
+ */
+ DiffuseWrapMethod.prototype.iCleanCompilationData = function () {
+ _super.prototype.iCleanCompilationData.call(this);
+ this._wrapDataRegister = null;
+ };
+ Object.defineProperty(DiffuseWrapMethod.prototype, "wrapFactor", {
+ /**
+ * A factor to indicate the amount by which the light is allowed to wrap.
+ */
+ get: function () {
+ return this._wrapFactor;
+ },
+ set: function (value) {
+ this._wrapFactor = value;
+ this._wrapFactor = 1 / (value + 1);
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ DiffuseWrapMethod.prototype.iGetFragmentPreLightingCode = function (shaderObject, methodVO, registerCache, sharedRegisters) {
+ var code = _super.prototype.iGetFragmentPreLightingCode.call(this, shaderObject, methodVO, registerCache, sharedRegisters);
+ this._pIsFirstLight = true;
+ this._wrapDataRegister = registerCache.getFreeFragmentConstant();
+ methodVO.secondaryFragmentConstantsIndex = this._wrapDataRegister.index * 4;
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseWrapMethod.prototype.iGetFragmentCodePerLight = function (shaderObject, methodVO, lightDirReg, lightColReg, registerCache, sharedRegisters) {
+ var code = "";
+ var t;
+ // write in temporary if not first light, so we can add to total diffuse colour
+ if (this._pIsFirstLight) {
+ t = this._pTotalLightColorReg;
+ }
+ else {
+ t = registerCache.getFreeFragmentVectorTemp();
+ registerCache.addFragmentTempUsages(t, 1);
+ }
+ code += "dp3 " + t + ".x, " + lightDirReg + ".xyz, " + sharedRegisters.normalFragment + ".xyz\n" + "add " + t + ".y, " + t + ".x, " + this._wrapDataRegister + ".x\n" + "mul " + t + ".y, " + t + ".y, " + this._wrapDataRegister + ".y\n" + "sat " + t + ".w, " + t + ".y\n" + "mul " + t + ".xz, " + t + ".w, " + lightDirReg + ".wz\n";
+ if (this._iModulateMethod != null)
+ code += this._iModulateMethod(shaderObject, methodVO, lightDirReg, registerCache, sharedRegisters);
+ code += "mul " + t + ", " + t + ".x, " + lightColReg + "\n";
+ if (!this._pIsFirstLight) {
+ code += "add " + this._pTotalLightColorReg + ".xyz, " + this._pTotalLightColorReg + ".xyz, " + t + ".xyz\n";
+ registerCache.removeFragmentTempUsage(t);
+ }
+ this._pIsFirstLight = false;
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ DiffuseWrapMethod.prototype.iActivate = function (shaderObject, methodVO, stage) {
+ _super.prototype.iActivate.call(this, shaderObject, methodVO, stage);
+ var index = methodVO.secondaryFragmentConstantsIndex;
+ var data = shaderObject.fragmentConstantData;
+ data[index] = this._wrapFactor;
+ data[index + 1] = 1 / (this._wrapFactor + 1);
+ };
+ return DiffuseWrapMethod;
+})(DiffuseBasicMethod);
+module.exports = DiffuseWrapMethod;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["materials/methods/diffusewrapmethod.ts"],"names":["DiffuseWrapMethod","DiffuseWrapMethod.constructor","DiffuseWrapMethod.iCleanCompilationData","DiffuseWrapMethod.wrapFactor","DiffuseWrapMethod.iGetFragmentPreLightingCode","DiffuseWrapMethod.iGetFragmentCodePerLight","DiffuseWrapMethod.iActivate"],"mappings":"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","file":"materials/methods/DiffuseWrapMethod.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport MethodVO\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/MethodVO\");\nimport ShaderLightingObject\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderLightingObject\");\nimport ShaderRegisterCache\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterCache\");\nimport ShaderRegisterData\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterData\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\nimport DiffuseBasicMethod\t\t\t\t= require(\"awayjs-stagegl/lib/materials/methods/DiffuseBasicMethod\");\n\n/**\n * DiffuseWrapMethod is an alternative to DiffuseBasicMethod in which the light is allowed to be \"wrapped around\" the normally dark area, to some extent.\n * It can be used as a crude approximation to Oren-Nayar or simple subsurface scattering.\n */\nclass DiffuseWrapMethod extends DiffuseBasicMethod\n{\n\tprivate _wrapDataRegister:ShaderRegisterElement;\n\tprivate _wrapFactor:number;\n\n\t/**\n\t * Creates a new DiffuseWrapMethod object.\n\t * @param wrapFactor A factor to indicate the amount by which the light is allowed to wrap\n\t */\n\tconstructor(wrapFactor:number = .5)\n\t{\n\t\tsuper();\n\n\t\tthis.wrapFactor = wrapFactor;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iCleanCompilationData()\n\t{\n\t\tsuper.iCleanCompilationData();\n\n\t\tthis._wrapDataRegister = null;\n\t}\n\n\t/**\n\t * A factor to indicate the amount by which the light is allowed to wrap.\n\t */\n\tpublic get wrapFactor():number\n\t{\n\t\treturn this._wrapFactor;\n\t}\n\n\tpublic set wrapFactor(value:number)\n\t{\n\t\tthis._wrapFactor = value;\n\t\tthis._wrapFactor = 1/(value + 1);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iGetFragmentPreLightingCode(shaderObject:ShaderLightingObject, methodVO:MethodVO, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\tvar code:string = super.iGetFragmentPreLightingCode(shaderObject, methodVO, registerCache, sharedRegisters);\n\t\tthis._pIsFirstLight = true;\n\t\tthis._wrapDataRegister = registerCache.getFreeFragmentConstant();\n\t\tmethodVO.secondaryFragmentConstantsIndex = this._wrapDataRegister.index*4;\n\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iGetFragmentCodePerLight(shaderObject:ShaderLightingObject, methodVO:MethodVO, lightDirReg:ShaderRegisterElement, lightColReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\tvar code:string = \"\";\n\t\tvar t:ShaderRegisterElement;\n\n\t\t// write in temporary if not first light, so we can add to total diffuse colour\n\t\tif (this._pIsFirstLight) {\n\t\t\tt = this._pTotalLightColorReg;\n\t\t} else {\n\t\t\tt = registerCache.getFreeFragmentVectorTemp();\n\t\t\tregisterCache.addFragmentTempUsages(t, 1);\n\t\t}\n\n\t\tcode += \"dp3 \" + t + \".x, \" + lightDirReg + \".xyz, \" + sharedRegisters.normalFragment + \".xyz\\n\" +\n\t\t\t\"add \" + t + \".y, \" + t + \".x, \" + this._wrapDataRegister + \".x\\n\" +\n\t\t\t\"mul \" + t + \".y, \" + t + \".y, \" + this._wrapDataRegister + \".y\\n\" +\n\t\t\t\"sat \" + t + \".w, \" + t + \".y\\n\" +\n\t\t\t\"mul \" + t + \".xz, \" + t + \".w, \" + lightDirReg + \".wz\\n\";\n\n\t\tif (this._iModulateMethod != null)\n\t\t\tcode += this._iModulateMethod(shaderObject, methodVO, lightDirReg, registerCache, sharedRegisters);\n\n\t\tcode += \"mul \" + t + \", \" + t + \".x, \" + lightColReg + \"\\n\";\n\n\t\tif (!this._pIsFirstLight) {\n\t\t\tcode += \"add \" + this._pTotalLightColorReg + \".xyz, \" + this._pTotalLightColorReg + \".xyz, \" + t + \".xyz\\n\";\n\t\t\tregisterCache.removeFragmentTempUsage(t);\n\t\t}\n\n\t\tthis._pIsFirstLight = false;\n\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iActivate(shaderObject:ShaderLightingObject, methodVO:MethodVO, stage:Stage)\n\t{\n\t\tsuper.iActivate(shaderObject, methodVO, stage);\n\n\t\tvar index:number /*int*/ = methodVO.secondaryFragmentConstantsIndex;\n\t\tvar data:Array<number> = shaderObject.fragmentConstantData;\n\t\tdata[index] = this._wrapFactor;\n\t\tdata[index + 1] = 1/(this._wrapFactor + 1);\n\t}\n}\n\nexport = DiffuseWrapMethod;"]}
\ No newline at end of file
diff --git a/lib/materials/methods/DiffuseWrapMethod.ts b/lib/materials/methods/DiffuseWrapMethod.ts
new file mode 100644
index 000000000..1f84822d9
--- /dev/null
+++ b/lib/materials/methods/DiffuseWrapMethod.ts
@@ -0,0 +1,117 @@
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import MethodVO = require("awayjs-stagegl/lib/materials/compilation/MethodVO");
+import ShaderLightingObject = require("awayjs-stagegl/lib/materials/compilation/ShaderLightingObject");
+import ShaderRegisterCache = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterCache");
+import ShaderRegisterData = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterData");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+import DiffuseBasicMethod = require("awayjs-stagegl/lib/materials/methods/DiffuseBasicMethod");
+
+/**
+ * DiffuseWrapMethod is an alternative to DiffuseBasicMethod in which the light is allowed to be "wrapped around" the normally dark area, to some extent.
+ * It can be used as a crude approximation to Oren-Nayar or simple subsurface scattering.
+ */
+class DiffuseWrapMethod extends DiffuseBasicMethod
+{
+ private _wrapDataRegister:ShaderRegisterElement;
+ private _wrapFactor:number;
+
+ /**
+ * Creates a new DiffuseWrapMethod object.
+ * @param wrapFactor A factor to indicate the amount by which the light is allowed to wrap
+ */
+ constructor(wrapFactor:number = .5)
+ {
+ super();
+
+ this.wrapFactor = wrapFactor;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iCleanCompilationData()
+ {
+ super.iCleanCompilationData();
+
+ this._wrapDataRegister = null;
+ }
+
+ /**
+ * A factor to indicate the amount by which the light is allowed to wrap.
+ */
+ public get wrapFactor():number
+ {
+ return this._wrapFactor;
+ }
+
+ public set wrapFactor(value:number)
+ {
+ this._wrapFactor = value;
+ this._wrapFactor = 1/(value + 1);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iGetFragmentPreLightingCode(shaderObject:ShaderLightingObject, methodVO:MethodVO, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ var code:string = super.iGetFragmentPreLightingCode(shaderObject, methodVO, registerCache, sharedRegisters);
+ this._pIsFirstLight = true;
+ this._wrapDataRegister = registerCache.getFreeFragmentConstant();
+ methodVO.secondaryFragmentConstantsIndex = this._wrapDataRegister.index*4;
+
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iGetFragmentCodePerLight(shaderObject:ShaderLightingObject, methodVO:MethodVO, lightDirReg:ShaderRegisterElement, lightColReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ var code:string = "";
+ var t:ShaderRegisterElement;
+
+ // write in temporary if not first light, so we can add to total diffuse colour
+ if (this._pIsFirstLight) {
+ t = this._pTotalLightColorReg;
+ } else {
+ t = registerCache.getFreeFragmentVectorTemp();
+ registerCache.addFragmentTempUsages(t, 1);
+ }
+
+ code += "dp3 " + t + ".x, " + lightDirReg + ".xyz, " + sharedRegisters.normalFragment + ".xyz\n" +
+ "add " + t + ".y, " + t + ".x, " + this._wrapDataRegister + ".x\n" +
+ "mul " + t + ".y, " + t + ".y, " + this._wrapDataRegister + ".y\n" +
+ "sat " + t + ".w, " + t + ".y\n" +
+ "mul " + t + ".xz, " + t + ".w, " + lightDirReg + ".wz\n";
+
+ if (this._iModulateMethod != null)
+ code += this._iModulateMethod(shaderObject, methodVO, lightDirReg, registerCache, sharedRegisters);
+
+ code += "mul " + t + ", " + t + ".x, " + lightColReg + "\n";
+
+ if (!this._pIsFirstLight) {
+ code += "add " + this._pTotalLightColorReg + ".xyz, " + this._pTotalLightColorReg + ".xyz, " + t + ".xyz\n";
+ registerCache.removeFragmentTempUsage(t);
+ }
+
+ this._pIsFirstLight = false;
+
+ return code;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iActivate(shaderObject:ShaderLightingObject, methodVO:MethodVO, stage:Stage)
+ {
+ super.iActivate(shaderObject, methodVO, stage);
+
+ var index:number /*int*/ = methodVO.secondaryFragmentConstantsIndex;
+ var data:Array = shaderObject.fragmentConstantData;
+ data[index] = this._wrapFactor;
+ data[index + 1] = 1/(this._wrapFactor + 1);
+ }
+}
+
+export = DiffuseWrapMethod;
\ No newline at end of file
diff --git a/lib/materials/methods/EffectAlphaMaskMethod.js b/lib/materials/methods/EffectAlphaMaskMethod.js
new file mode 100755
index 000000000..aa229bf2b
--- /dev/null
+++ b/lib/materials/methods/EffectAlphaMaskMethod.js
@@ -0,0 +1,86 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var EffectMethodBase = require("awayjs-stagegl/lib/materials/methods/EffectMethodBase");
+var ShaderCompilerHelper = require("awayjs-stagegl/lib/materials/utils/ShaderCompilerHelper");
+/**
+ * EffectAlphaMaskMethod allows the use of an additional texture to specify the alpha value of the material. When used
+ * with the secondary uv set, it allows for a tiled main texture with independently varying alpha (useful for water
+ * etc).
+ */
+var EffectAlphaMaskMethod = (function (_super) {
+ __extends(EffectAlphaMaskMethod, _super);
+ /**
+ * Creates a new EffectAlphaMaskMethod object.
+ *
+ * @param texture The texture to use as the alpha mask.
+ * @param useSecondaryUV Indicated whether or not the secondary uv set for the mask. This allows mapping alpha independently.
+ */
+ function EffectAlphaMaskMethod(texture, useSecondaryUV) {
+ if (useSecondaryUV === void 0) { useSecondaryUV = false; }
+ _super.call(this);
+ this._texture = texture;
+ this._useSecondaryUV = useSecondaryUV;
+ }
+ /**
+ * @inheritDoc
+ */
+ EffectAlphaMaskMethod.prototype.iInitVO = function (shaderObject, methodVO) {
+ methodVO.needsSecondaryUV = this._useSecondaryUV;
+ methodVO.needsUV = !this._useSecondaryUV;
+ };
+ Object.defineProperty(EffectAlphaMaskMethod.prototype, "useSecondaryUV", {
+ /**
+ * Indicated whether or not the secondary uv set for the mask. This allows mapping alpha independently, for
+ * instance to tile the main texture and normal map while providing untiled alpha, for example to define the
+ * transparency over a tiled water surface.
+ */
+ get: function () {
+ return this._useSecondaryUV;
+ },
+ set: function (value) {
+ if (this._useSecondaryUV == value)
+ return;
+ this._useSecondaryUV = value;
+ this.iInvalidateShaderProgram();
+ },
+ enumerable: true,
+ configurable: true
+ });
+ Object.defineProperty(EffectAlphaMaskMethod.prototype, "texture", {
+ /**
+ * The texture to use as the alpha mask.
+ */
+ get: function () {
+ return this._texture;
+ },
+ set: function (value) {
+ this._texture = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ EffectAlphaMaskMethod.prototype.iActivate = function (shaderObject, methodVO, stage) {
+ stage.context.activateTexture(methodVO.texturesIndex, this._texture);
+ };
+ /**
+ * @inheritDoc
+ */
+ EffectAlphaMaskMethod.prototype.iGetFragmentCode = function (shaderObject, methodVO, targetReg, registerCache, sharedRegisters) {
+ var textureReg = registerCache.getFreeTextureReg();
+ var temp = registerCache.getFreeFragmentVectorTemp();
+ var uvReg = this._useSecondaryUV ? sharedRegisters.secondaryUVVarying : sharedRegisters.uvVarying;
+ methodVO.texturesIndex = textureReg.index;
+ return ShaderCompilerHelper.getTex2DSampleCode(temp, sharedRegisters, textureReg, this._texture, shaderObject.useSmoothTextures, shaderObject.repeatTextures, shaderObject.useMipmapping, uvReg) + "mul " + targetReg + ", " + targetReg + ", " + temp + ".x\n";
+ };
+ return EffectAlphaMaskMethod;
+})(EffectMethodBase);
+module.exports = EffectAlphaMaskMethod;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["materials/methods/effectalphamaskmethod.ts"],"names":["EffectAlphaMaskMethod","EffectAlphaMaskMethod.constructor","EffectAlphaMaskMethod.iInitVO","EffectAlphaMaskMethod.useSecondaryUV","EffectAlphaMaskMethod.texture","EffectAlphaMaskMethod.iActivate","EffectAlphaMaskMethod.iGetFragmentCode"],"mappings":";;;;;;AAUA,IAAO,gBAAgB,WAAe,uDAAuD,CAAC,CAAC;AAC/F,IAAO,oBAAoB,WAAc,yDAAyD,CAAC,CAAC;AAEpG,AAKA;;;;GADG;IACG,qBAAqB;IAASA,UAA9BA,qBAAqBA,UAAyBA;IAKnDA;;;;;OAKGA;IACHA,SAXKA,qBAAqBA,CAWdA,OAAqBA,EAAEA,cAA8BA;QAA9BC,8BAA8BA,GAA9BA,sBAA8BA;QAEhEA,iBAAOA,CAACA;QAERA,IAAIA,CAACA,QAAQA,GAAGA,OAAOA,CAACA;QACxBA,IAAIA,CAACA,eAAeA,GAAGA,cAAcA,CAACA;IACvCA,CAACA;IAEDD;;OAEGA;IACIA,uCAAOA,GAAdA,UAAeA,YAA6BA,EAAEA,QAAiBA;QAE9DE,QAAQA,CAACA,gBAAgBA,GAAGA,IAAIA,CAACA,eAAeA,CAACA;QACjDA,QAAQA,CAACA,OAAOA,GAAGA,CAACA,IAAIA,CAACA,eAAeA,CAACA;IAC1CA,CAACA;IAODF,sBAAWA,iDAAcA;QALzBA;;;;WAIGA;aACHA;YAECG,MAAMA,CAACA,IAAIA,CAACA,eAAeA,CAACA;QAC7BA,CAACA;aAEDH,UAA0BA,KAAaA;YAEtCG,EAAEA,CAACA,CAACA,IAAIA,CAACA,eAAeA,IAAIA,KAAKA,CAACA;gBACjCA,MAAMA,CAACA;YACRA,IAAIA,CAACA,eAAeA,GAAGA,KAAKA,CAACA;YAC7BA,IAAIA,CAACA,wBAAwBA,EAAEA,CAACA;QACjCA,CAACA;;;OARAH;IAaDA,sBAAWA,0CAAOA;QAHlBA;;WAEGA;aACHA;YAECI,MAAMA,CAACA,IAAIA,CAACA,QAAQA,CAACA;QACtBA,CAACA;aAEDJ,UAAmBA,KAAmBA;YAErCI,IAAIA,CAACA,QAAQA,GAAGA,KAAKA,CAACA;QACvBA,CAACA;;;OALAJ;IAODA;;OAEGA;IACIA,yCAASA,GAAhBA,UAAiBA,YAAiCA,EAAEA,QAAiBA,EAAEA,KAAWA;QAE9DK,KAAKA,CAACA,OAAQA,CAACA,eAAeA,CAACA,QAAQA,CAACA,aAAaA,EAAEA,IAAIA,CAACA,QAAQA,CAACA,CAACA;IAC1FA,CAACA;IAEDL;;OAEGA;IACIA,gDAAgBA,GAAvBA,UAAwBA,YAA6BA,EAAEA,QAAiBA,EAAEA,SAA+BA,EAAEA,aAAiCA,EAAEA,eAAkCA;QAE/KM,IAAIA,UAAUA,GAAyBA,aAAaA,CAACA,iBAAiBA,EAAEA,CAACA;QACzEA,IAAIA,IAAIA,GAAyBA,aAAaA,CAACA,yBAAyBA,EAAEA,CAACA;QAC3EA,IAAIA,KAAKA,GAAyBA,IAAIA,CAACA,eAAeA,GAAEA,eAAeA,CAACA,kBAAkBA,GAAGA,eAAeA,CAACA,SAASA,CAACA;QACvHA,QAAQA,CAACA,aAAaA,GAAGA,UAAUA,CAACA,KAAKA,CAACA;QAE1CA,MAAMA,CAACA,oBAAoBA,CAACA,kBAAkBA,CAACA,IAAIA,EAAEA,eAAeA,EAAEA,UAAUA,EAAEA,IAAIA,CAACA,QAAQA,EAAEA,YAAYA,CAACA,iBAAiBA,EAAEA,YAAYA,CAACA,cAAcA,EAAEA,YAAYA,CAACA,aAAaA,EAAEA,KAAKA,CAACA,GAC/LA,MAAMA,GAAGA,SAASA,GAAGA,IAAIA,GAAGA,SAASA,GAAGA,IAAIA,GAAGA,IAAIA,GAAGA,MAAMA,CAACA;IAC/DA,CAACA;IACFN,4BAACA;AAADA,CAhFA,AAgFCA,EAhFmC,gBAAgB,EAgFnD;AAED,AAA+B,iBAAtB,qBAAqB,CAAC","file":"materials/methods/EffectAlphaMaskMethod.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Texture2DBase\t\t\t\t\t= require(\"awayjs-core/lib/textures/Texture2DBase\");\n\nimport Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport IContextStageGL\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/stagegl/IContextStageGL\");\nimport MethodVO\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/MethodVO\");\nimport ShaderLightingObject\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderLightingObject\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterCache\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterCache\");\nimport ShaderRegisterData\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterData\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\nimport EffectMethodBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/methods/EffectMethodBase\");\nimport ShaderCompilerHelper\t\t\t\t= require(\"awayjs-stagegl/lib/materials/utils/ShaderCompilerHelper\");\n\n/**\n * EffectAlphaMaskMethod allows the use of an additional texture to specify the alpha value of the material. When used\n * with the secondary uv set, it allows for a tiled main texture with independently varying alpha (useful for water\n * etc).\n */\nclass EffectAlphaMaskMethod extends EffectMethodBase\n{\n\tprivate _texture:Texture2DBase;\n\tprivate _useSecondaryUV:boolean;\n\n\t/**\n\t * Creates a new EffectAlphaMaskMethod object.\n\t *\n\t * @param texture The texture to use as the alpha mask.\n\t * @param useSecondaryUV Indicated whether or not the secondary uv set for the mask. This allows mapping alpha independently.\n\t */\n\tconstructor(texture:Texture2DBase, useSecondaryUV:boolean = false)\n\t{\n\t\tsuper();\n\n\t\tthis._texture = texture;\n\t\tthis._useSecondaryUV = useSecondaryUV;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iInitVO(shaderObject:ShaderObjectBase, methodVO:MethodVO)\n\t{\n\t\tmethodVO.needsSecondaryUV = this._useSecondaryUV;\n\t\tmethodVO.needsUV = !this._useSecondaryUV;\n\t}\n\n\t/**\n\t * Indicated whether or not the secondary uv set for the mask. This allows mapping alpha independently, for\n\t * instance to tile the main texture and normal map while providing untiled alpha, for example to define the\n\t * transparency over a tiled water surface.\n\t */\n\tpublic get useSecondaryUV():boolean\n\t{\n\t\treturn this._useSecondaryUV;\n\t}\n\n\tpublic set useSecondaryUV(value:boolean)\n\t{\n\t\tif (this._useSecondaryUV == value)\n\t\t\treturn;\n\t\tthis._useSecondaryUV = value;\n\t\tthis.iInvalidateShaderProgram();\n\t}\n\n\t/**\n\t * The texture to use as the alpha mask.\n\t */\n\tpublic get texture():Texture2DBase\n\t{\n\t\treturn this._texture;\n\t}\n\n\tpublic set texture(value:Texture2DBase)\n\t{\n\t\tthis._texture = value;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iActivate(shaderObject:ShaderLightingObject, methodVO:MethodVO, stage:Stage)\n\t{\n\t\t(<IContextStageGL> stage.context).activateTexture(methodVO.texturesIndex, this._texture);\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iGetFragmentCode(shaderObject:ShaderObjectBase, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\tvar textureReg:ShaderRegisterElement = registerCache.getFreeTextureReg();\n\t\tvar temp:ShaderRegisterElement = registerCache.getFreeFragmentVectorTemp();\n\t\tvar uvReg:ShaderRegisterElement = this._useSecondaryUV? sharedRegisters.secondaryUVVarying : sharedRegisters.uvVarying;\n\t\tmethodVO.texturesIndex = textureReg.index;\n\n\t\treturn ShaderCompilerHelper.getTex2DSampleCode(temp, sharedRegisters, textureReg, this._texture, shaderObject.useSmoothTextures, shaderObject.repeatTextures, shaderObject.useMipmapping, uvReg) +\n\t\t\t\"mul \" + targetReg + \", \" + targetReg + \", \" + temp + \".x\\n\";\n\t}\n}\n\nexport = EffectAlphaMaskMethod;"]}
\ No newline at end of file
diff --git a/lib/materials/methods/EffectAlphaMaskMethod.ts b/lib/materials/methods/EffectAlphaMaskMethod.ts
new file mode 100644
index 000000000..e4cc62a76
--- /dev/null
+++ b/lib/materials/methods/EffectAlphaMaskMethod.ts
@@ -0,0 +1,101 @@
+import Texture2DBase = require("awayjs-core/lib/textures/Texture2DBase");
+
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import IContextStageGL = require("awayjs-stagegl/lib/core/stagegl/IContextStageGL");
+import MethodVO = require("awayjs-stagegl/lib/materials/compilation/MethodVO");
+import ShaderLightingObject = require("awayjs-stagegl/lib/materials/compilation/ShaderLightingObject");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterCache = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterCache");
+import ShaderRegisterData = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterData");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+import EffectMethodBase = require("awayjs-stagegl/lib/materials/methods/EffectMethodBase");
+import ShaderCompilerHelper = require("awayjs-stagegl/lib/materials/utils/ShaderCompilerHelper");
+
+/**
+ * EffectAlphaMaskMethod allows the use of an additional texture to specify the alpha value of the material. When used
+ * with the secondary uv set, it allows for a tiled main texture with independently varying alpha (useful for water
+ * etc).
+ */
+class EffectAlphaMaskMethod extends EffectMethodBase
+{
+ private _texture:Texture2DBase;
+ private _useSecondaryUV:boolean;
+
+ /**
+ * Creates a new EffectAlphaMaskMethod object.
+ *
+ * @param texture The texture to use as the alpha mask.
+ * @param useSecondaryUV Indicated whether or not the secondary uv set for the mask. This allows mapping alpha independently.
+ */
+ constructor(texture:Texture2DBase, useSecondaryUV:boolean = false)
+ {
+ super();
+
+ this._texture = texture;
+ this._useSecondaryUV = useSecondaryUV;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iInitVO(shaderObject:ShaderObjectBase, methodVO:MethodVO)
+ {
+ methodVO.needsSecondaryUV = this._useSecondaryUV;
+ methodVO.needsUV = !this._useSecondaryUV;
+ }
+
+ /**
+ * Indicated whether or not the secondary uv set for the mask. This allows mapping alpha independently, for
+ * instance to tile the main texture and normal map while providing untiled alpha, for example to define the
+ * transparency over a tiled water surface.
+ */
+ public get useSecondaryUV():boolean
+ {
+ return this._useSecondaryUV;
+ }
+
+ public set useSecondaryUV(value:boolean)
+ {
+ if (this._useSecondaryUV == value)
+ return;
+ this._useSecondaryUV = value;
+ this.iInvalidateShaderProgram();
+ }
+
+ /**
+ * The texture to use as the alpha mask.
+ */
+ public get texture():Texture2DBase
+ {
+ return this._texture;
+ }
+
+ public set texture(value:Texture2DBase)
+ {
+ this._texture = value;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iActivate(shaderObject:ShaderLightingObject, methodVO:MethodVO, stage:Stage)
+ {
+ ( stage.context).activateTexture(methodVO.texturesIndex, this._texture);
+ }
+
+ /**
+ * @inheritDoc
+ */
+ public iGetFragmentCode(shaderObject:ShaderObjectBase, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string
+ {
+ var textureReg:ShaderRegisterElement = registerCache.getFreeTextureReg();
+ var temp:ShaderRegisterElement = registerCache.getFreeFragmentVectorTemp();
+ var uvReg:ShaderRegisterElement = this._useSecondaryUV? sharedRegisters.secondaryUVVarying : sharedRegisters.uvVarying;
+ methodVO.texturesIndex = textureReg.index;
+
+ return ShaderCompilerHelper.getTex2DSampleCode(temp, sharedRegisters, textureReg, this._texture, shaderObject.useSmoothTextures, shaderObject.repeatTextures, shaderObject.useMipmapping, uvReg) +
+ "mul " + targetReg + ", " + targetReg + ", " + temp + ".x\n";
+ }
+}
+
+export = EffectAlphaMaskMethod;
\ No newline at end of file
diff --git a/lib/materials/methods/EffectColorMatrixMethod.js b/lib/materials/methods/EffectColorMatrixMethod.js
new file mode 100755
index 000000000..a4d6299e6
--- /dev/null
+++ b/lib/materials/methods/EffectColorMatrixMethod.js
@@ -0,0 +1,89 @@
+var __extends = this.__extends || function (d, b) {
+ for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
+ function __() { this.constructor = d; }
+ __.prototype = b.prototype;
+ d.prototype = new __();
+};
+var EffectMethodBase = require("awayjs-stagegl/lib/materials/methods/EffectMethodBase");
+/**
+ * EffectColorMatrixMethod provides a shading method that changes the colour of a material analogous to a ColorMatrixFilter.
+ */
+var EffectColorMatrixMethod = (function (_super) {
+ __extends(EffectColorMatrixMethod, _super);
+ /**
+ * Creates a new EffectColorTransformMethod.
+ *
+ * @param matrix An array of 20 items for 4 x 5 color transform.
+ */
+ function EffectColorMatrixMethod(matrix) {
+ _super.call(this);
+ if (matrix.length != 20)
+ throw new Error("Matrix length must be 20!");
+ this._matrix = matrix;
+ }
+ Object.defineProperty(EffectColorMatrixMethod.prototype, "colorMatrix", {
+ /**
+ * The 4 x 5 matrix to transform the color of the material.
+ */
+ get: function () {
+ return this._matrix;
+ },
+ set: function (value) {
+ this._matrix = value;
+ },
+ enumerable: true,
+ configurable: true
+ });
+ /**
+ * @inheritDoc
+ */
+ EffectColorMatrixMethod.prototype.iGetFragmentCode = function (shaderObject, methodVO, targetReg, registerCache, sharedRegisters) {
+ var code = "";
+ var colorMultReg = registerCache.getFreeFragmentConstant();
+ registerCache.getFreeFragmentConstant();
+ registerCache.getFreeFragmentConstant();
+ registerCache.getFreeFragmentConstant();
+ var colorOffsetReg = registerCache.getFreeFragmentConstant();
+ methodVO.fragmentConstantsIndex = colorMultReg.index * 4;
+ var temp = registerCache.getFreeFragmentVectorTemp();
+ code += "m44 " + temp + ", " + targetReg + ", " + colorMultReg + "\n" + "add " + targetReg + ", " + temp + ", " + colorOffsetReg + "\n";
+ return code;
+ };
+ /**
+ * @inheritDoc
+ */
+ EffectColorMatrixMethod.prototype.iActivate = function (shaderObject, methodVO, stage) {
+ var matrix = this._matrix;
+ var index = methodVO.fragmentConstantsIndex;
+ var data = shaderObject.fragmentConstantData;
+ // r
+ data[index] = matrix[0];
+ data[index + 1] = matrix[1];
+ data[index + 2] = matrix[2];
+ data[index + 3] = matrix[3];
+ // g
+ data[index + 4] = matrix[5];
+ data[index + 5] = matrix[6];
+ data[index + 6] = matrix[7];
+ data[index + 7] = matrix[8];
+ // b
+ data[index + 8] = matrix[10];
+ data[index + 9] = matrix[11];
+ data[index + 10] = matrix[12];
+ data[index + 11] = matrix[13];
+ // a
+ data[index + 12] = matrix[15];
+ data[index + 13] = matrix[16];
+ data[index + 14] = matrix[17];
+ data[index + 15] = matrix[18];
+ // rgba offset
+ data[index + 16] = matrix[4];
+ data[index + 17] = matrix[9];
+ data[index + 18] = matrix[14];
+ data[index + 19] = matrix[19];
+ };
+ return EffectColorMatrixMethod;
+})(EffectMethodBase);
+module.exports = EffectColorMatrixMethod;
+
+//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["materials/methods/effectcolormatrixmethod.ts"],"names":["EffectColorMatrixMethod","EffectColorMatrixMethod.constructor","EffectColorMatrixMethod.colorMatrix","EffectColorMatrixMethod.iGetFragmentCode","EffectColorMatrixMethod.iActivate"],"mappings":"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","file":"materials/methods/EffectColorMatrixMethod.js","sourceRoot":"/Users/robbateman/WebstormProjects/awayjs-renderergl/","sourcesContent":["import Stage\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/core/base/Stage\");\nimport MethodVO\t\t\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/MethodVO\");\nimport ShaderObjectBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderObjectBase\");\nimport ShaderRegisterCache\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterCache\");\nimport ShaderRegisterData\t\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterData\");\nimport ShaderRegisterElement\t\t\t= require(\"awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement\");\nimport EffectMethodBase\t\t\t\t\t= require(\"awayjs-stagegl/lib/materials/methods/EffectMethodBase\");\n\n/**\n * EffectColorMatrixMethod provides a shading method that changes the colour of a material analogous to a ColorMatrixFilter.\n */\nclass EffectColorMatrixMethod extends EffectMethodBase\n{\n\tprivate _matrix:Array<number>;\n\n\t/**\n\t * Creates a new EffectColorTransformMethod.\n\t *\n\t * @param matrix An array of 20 items for 4 x 5 color transform.\n\t */\n\tconstructor(matrix:Array<number>)\n\t{\n\t\tsuper();\n\n\t\tif (matrix.length != 20)\n\t\t\tthrow new Error(\"Matrix length must be 20!\");\n\n\t\tthis._matrix = matrix;\n\t}\n\n\t/**\n\t * The 4 x 5 matrix to transform the color of the material.\n\t */\n\tpublic get colorMatrix():Array<number>\n\t{\n\t\treturn this._matrix;\n\t}\n\n\tpublic set colorMatrix(value:Array<number>)\n\t{\n\t\tthis._matrix = value;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iGetFragmentCode(shaderObject:ShaderObjectBase, methodVO:MethodVO, targetReg:ShaderRegisterElement, registerCache:ShaderRegisterCache, sharedRegisters:ShaderRegisterData):string\n\t{\n\t\tvar code:string = \"\";\n\t\tvar colorMultReg:ShaderRegisterElement = registerCache.getFreeFragmentConstant();\n\t\tregisterCache.getFreeFragmentConstant();\n\t\tregisterCache.getFreeFragmentConstant();\n\t\tregisterCache.getFreeFragmentConstant();\n\n\t\tvar colorOffsetReg:ShaderRegisterElement = registerCache.getFreeFragmentConstant();\n\n\t\tmethodVO.fragmentConstantsIndex = colorMultReg.index*4;\n\n\t\tvar temp:ShaderRegisterElement = registerCache.getFreeFragmentVectorTemp();\n\n\t\tcode += \"m44 \" + temp + \", \" + targetReg + \", \" + colorMultReg + \"\\n\" +\n\t\t\t\t\"add \" + targetReg + \", \" + temp + \", \" + colorOffsetReg + \"\\n\";\n\n\t\treturn code;\n\t}\n\n\t/**\n\t * @inheritDoc\n\t */\n\tpublic iActivate(shaderObject:ShaderObjectBase, methodVO:MethodVO, stage:Stage)\n\t{\n\t\tvar matrix:Array<number> = this._matrix;\n\t\tvar index:number /*int*/ = methodVO.fragmentConstantsIndex;\n\t\tvar data:Array<number> = shaderObject.fragmentConstantData;\n\n\t\t// r\n\t\tdata[index] = matrix[0];\n\t\tdata[index + 1] = matrix[1];\n\t\tdata[index + 2] = matrix[2];\n\t\tdata[index + 3] = matrix[3];\n\n\t\t// g\n\t\tdata[index + 4] = matrix[5];\n\t\tdata[index + 5] = matrix[6];\n\t\tdata[index + 6] = matrix[7];\n\t\tdata[index + 7] = matrix[8];\n\n\t\t// b\n\t\tdata[index + 8] = matrix[10];\n\t\tdata[index + 9] = matrix[11];\n\t\tdata[index + 10] = matrix[12];\n\t\tdata[index + 11] = matrix[13];\n\n\t\t// a\n\t\tdata[index + 12] = matrix[15];\n\t\tdata[index + 13] = matrix[16];\n\t\tdata[index + 14] = matrix[17];\n\t\tdata[index + 15] = matrix[18];\n\n\t\t// rgba offset\n\t\tdata[index + 16] = matrix[4];\n\t\tdata[index + 17] = matrix[9];\n\t\tdata[index + 18] = matrix[14];\n\t\tdata[index + 19] = matrix[19];\n\t}\n}\n\nexport = EffectColorMatrixMethod;"]}
\ No newline at end of file
diff --git a/lib/materials/methods/EffectColorMatrixMethod.ts b/lib/materials/methods/EffectColorMatrixMethod.ts
new file mode 100644
index 000000000..d4fa01402
--- /dev/null
+++ b/lib/materials/methods/EffectColorMatrixMethod.ts
@@ -0,0 +1,108 @@
+import Stage = require("awayjs-stagegl/lib/core/base/Stage");
+import MethodVO = require("awayjs-stagegl/lib/materials/compilation/MethodVO");
+import ShaderObjectBase = require("awayjs-stagegl/lib/materials/compilation/ShaderObjectBase");
+import ShaderRegisterCache = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterCache");
+import ShaderRegisterData = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterData");
+import ShaderRegisterElement = require("awayjs-stagegl/lib/materials/compilation/ShaderRegisterElement");
+import EffectMethodBase = require("awayjs-stagegl/lib/materials/methods/EffectMethodBase");
+
+/**
+ * EffectColorMatrixMethod provides a shading method that changes the colour of a material analogous to a ColorMatrixFilter.
+ */
+class EffectColorMatrixMethod extends EffectMethodBase
+{
+ private _matrix:Array;
+
+ /**
+ * Creates a new EffectColorTransformMethod.
+ *
+ * @param matrix An array of 20 items for 4 x 5 color transform.
+ */
+ constructor(matrix:Array