diff options
Diffstat (limited to 'js/panels/Timeline/PropertyTrack.reel/PropertyTrack.js')
-rw-r--r-- | js/panels/Timeline/PropertyTrack.reel/PropertyTrack.js | 27 |
1 files changed, 26 insertions, 1 deletions
diff --git a/js/panels/Timeline/PropertyTrack.reel/PropertyTrack.js b/js/panels/Timeline/PropertyTrack.reel/PropertyTrack.js index b46a6242..dd440d9e 100644 --- a/js/panels/Timeline/PropertyTrack.reel/PropertyTrack.js +++ b/js/panels/Timeline/PropertyTrack.reel/PropertyTrack.js | |||
@@ -9,11 +9,13 @@ var Component = require("montage/ui/component").Component; | |||
9 | 9 | ||
10 | var PropertyTrack = exports.PropertyTrack = Montage.create(Component, { | 10 | var PropertyTrack = exports.PropertyTrack = Montage.create(Component, { |
11 | 11 | ||
12 | /* Begin: Models */ | 12 | |
13 | hasTemplate:{ | 13 | hasTemplate:{ |
14 | value: true | 14 | value: true |
15 | }, | 15 | }, |
16 | 16 | ||
17 | /* Begin: Models */ | ||
18 | |||
17 | _propTweenRepetition:{ | 19 | _propTweenRepetition:{ |
18 | value:null | 20 | value:null |
19 | }, | 21 | }, |
@@ -283,10 +285,13 @@ var PropertyTrack = exports.PropertyTrack = Montage.create(Component, { | |||
283 | currentMillisec = currentMillisecPerPixel * clickPos; | 285 | currentMillisec = currentMillisecPerPixel * clickPos; |
284 | this.trackDuration = currentMillisec; | 286 | this.trackDuration = currentMillisec; |
285 | 287 | ||
288 | /* Creating a newTween Object */ | ||
286 | newTween = {}; | 289 | newTween = {}; |
287 | newTween.tweenData = {}; | 290 | newTween.tweenData = {}; |
288 | newTween.tweenData.tweenedProperties = []; | 291 | newTween.tweenData.tweenedProperties = []; |
289 | 292 | ||
293 | /* Getting the Property Style for the animatedElement */ | ||
294 | |||
290 | propVal = this.ninjaStylesContoller.getElementStyle(this.animatedElement, this.trackEditorProperty); | 295 | propVal = this.ninjaStylesContoller.getElementStyle(this.animatedElement, this.trackEditorProperty); |
291 | if(propVal == null){ | 296 | if(propVal == null){ |
292 | propVal = "1px"; | 297 | propVal = "1px"; |
@@ -294,6 +299,9 @@ var PropertyTrack = exports.PropertyTrack = Montage.create(Component, { | |||
294 | newTween.tweenData.tweenedProperties[this.trackEditorProperty] = propVal; | 299 | newTween.tweenData.tweenedProperties[this.trackEditorProperty] = propVal; |
295 | 300 | ||
296 | if (clickPos == 0) { | 301 | if (clickPos == 0) { |
302 | |||
303 | /* Setting the tweenData Properties for the first Keyframe */ | ||
304 | |||
297 | newTween.tweenData.spanWidth = 0; | 305 | newTween.tweenData.spanWidth = 0; |
298 | newTween.tweenData.keyFramePosition = 0; | 306 | newTween.tweenData.keyFramePosition = 0; |
299 | newTween.tweenData.keyFrameMillisec = 0; | 307 | newTween.tweenData.keyFrameMillisec = 0; |
@@ -327,13 +335,18 @@ var PropertyTrack = exports.PropertyTrack = Montage.create(Component, { | |||
327 | splitTweenIndex, | 335 | splitTweenIndex, |
328 | newTweenToInsert; | 336 | newTweenToInsert; |
329 | 337 | ||
338 | /* Traverse through the property tweens array */ | ||
339 | |||
330 | for (i = 0; i < tweensLength; i++) { | 340 | for (i = 0; i < tweensLength; i++) { |
331 | prevTween = this.propTweens[i].tweenData.keyFramePosition; | 341 | prevTween = this.propTweens[i].tweenData.keyFramePosition; |
332 | nextTween = this.propTweens[i + 1].tweenData.keyFramePosition; | 342 | nextTween = this.propTweens[i + 1].tweenData.keyFramePosition; |
333 | if (position > prevTween && position < nextTween) { | 343 | if (position > prevTween && position < nextTween) { |
334 | 344 | ||
345 | /* Insert a new tween at this index */ | ||
335 | splitTweenIndex = i + 1; | 346 | splitTweenIndex = i + 1; |
336 | 347 | ||
348 | /* Update the next tween to have new span position and width */ | ||
349 | |||
337 | this.propTweens[i + 1].tweenData.spanPosition = position; | 350 | this.propTweens[i + 1].tweenData.spanPosition = position; |
338 | this.propTweens[i + 1].spanPosition = position; | 351 | this.propTweens[i + 1].spanPosition = position; |
339 | this.propTweens[i + 1].tweenData.spanWidth = this.propTweens[i + 1].tweenData.keyFramePosition - position; | 352 | this.propTweens[i + 1].tweenData.spanWidth = this.propTweens[i + 1].tweenData.keyFramePosition - position; |
@@ -346,6 +359,7 @@ var PropertyTrack = exports.PropertyTrack = Montage.create(Component, { | |||
346 | } | 359 | } |
347 | this.propTweenRepetition.childComponents[nextComponentIndex].setData(); | 360 | this.propTweenRepetition.childComponents[nextComponentIndex].setData(); |
348 | 361 | ||
362 | /* Create a new Tween and splice it into the model */ | ||
349 | newTweenToInsert = {}; | 363 | newTweenToInsert = {}; |
350 | newTweenToInsert.tweenData = {}; | 364 | newTweenToInsert.tweenData = {}; |
351 | newTweenToInsert.tweenData.spanWidth = position - prevTween; | 365 | newTweenToInsert.tweenData.spanWidth = position - prevTween; |
@@ -393,12 +407,15 @@ var PropertyTrack = exports.PropertyTrack = Montage.create(Component, { | |||
393 | trackTiming = this.application.ninja.stylesController.getElementStyle(this.animatedElement, "-webkit-animation-duration"); | 407 | trackTiming = this.application.ninja.stylesController.getElementStyle(this.animatedElement, "-webkit-animation-duration"); |
394 | this.nextKeyframe = 0; | 408 | this.nextKeyframe = 0; |
395 | 409 | ||
410 | /* Traverse through the currentKeyFrameRule for the animatedElement */ | ||
411 | |||
396 | for (i = 0; this.currentKeyframeRule[i]; i++) { | 412 | for (i = 0; this.currentKeyframeRule[i]; i++) { |
397 | newTween = {}; | 413 | newTween = {}; |
398 | newTween.tweenData = {}; | 414 | newTween.tweenData = {}; |
399 | 415 | ||
400 | styleLength = this.currentKeyframeRule[i].style.length, keyframeStyles = []; | 416 | styleLength = this.currentKeyframeRule[i].style.length, keyframeStyles = []; |
401 | 417 | ||
418 | /* Traversering through the style of the currentKeyFrameRule of the animatedElement */ | ||
402 | for (j = 0; j < styleLength; j++) { | 419 | for (j = 0; j < styleLength; j++) { |
403 | 420 | ||
404 | firstChar = this.currentKeyframeRule[i].style[j].charAt(0); | 421 | firstChar = this.currentKeyframeRule[i].style[j].charAt(0); |
@@ -417,6 +434,8 @@ var PropertyTrack = exports.PropertyTrack = Montage.create(Component, { | |||
417 | } | 434 | } |
418 | 435 | ||
419 | if (this.currentKeyframeRule[i].keyText === "0%") { | 436 | if (this.currentKeyframeRule[i].keyText === "0%") { |
437 | |||
438 | /* Setting the tweenData Property for only the first Keyframe */ | ||
420 | newTween.tweenData.spanWidth = 0; | 439 | newTween.tweenData.spanWidth = 0; |
421 | newTween.tweenData.keyFramePosition = 0; | 440 | newTween.tweenData.keyFramePosition = 0; |
422 | newTween.tweenData.keyFrameMillisec = 0; | 441 | newTween.tweenData.keyFrameMillisec = 0; |
@@ -425,6 +444,7 @@ var PropertyTrack = exports.PropertyTrack = Montage.create(Component, { | |||
425 | this.propTweens.push(newTween); | 444 | this.propTweens.push(newTween); |
426 | } | 445 | } |
427 | else { | 446 | else { |
447 | |||
428 | tempTiming = trackTiming.split("s"); | 448 | tempTiming = trackTiming.split("s"); |
429 | tempTimingFloat = parseFloat(tempTiming[0]); | 449 | tempTimingFloat = parseFloat(tempTiming[0]); |
430 | this.trackDuration = tempTimingFloat * 1000; | 450 | this.trackDuration = tempTimingFloat * 1000; |
@@ -481,6 +501,9 @@ var PropertyTrack = exports.PropertyTrack = Montage.create(Component, { | |||
481 | 501 | ||
482 | addPropAnimationRuleToElement:{ | 502 | addPropAnimationRuleToElement:{ |
483 | value:function(tweenEvent){ | 503 | value:function(tweenEvent){ |
504 | |||
505 | /* Adding the style property as an animation rule to the animatedElement */ | ||
506 | |||
484 | var currentStyleValue, | 507 | var currentStyleValue, |
485 | currentAnimationNameString, | 508 | currentAnimationNameString, |
486 | newAnimationNames, | 509 | newAnimationNames, |
@@ -490,6 +513,7 @@ var PropertyTrack = exports.PropertyTrack = Montage.create(Component, { | |||
490 | newIterationCount, | 513 | newIterationCount, |
491 | initRule; | 514 | initRule; |
492 | 515 | ||
516 | /* Retrieveing the current style value on the animatedElement */ | ||
493 | currentStyleValue = this.ninjaStylesContoller.getElementStyle(this.animatedElement, this.trackEditorProperty); | 517 | currentStyleValue = this.ninjaStylesContoller.getElementStyle(this.animatedElement, this.trackEditorProperty); |
494 | if (currentStyleValue == null) { | 518 | if (currentStyleValue == null) { |
495 | currentStyleValue = "1px"; | 519 | currentStyleValue = "1px"; |
@@ -515,6 +539,7 @@ var PropertyTrack = exports.PropertyTrack = Montage.create(Component, { | |||
515 | this.ninjaStylesContoller.setElementStyle(this.animatedElement, "-webkit-animation-fill-mode", "forwards"); | 539 | this.ninjaStylesContoller.setElementStyle(this.animatedElement, "-webkit-animation-fill-mode", "forwards"); |
516 | this.ninjaStylesContoller.setElementStyle(this.animatedElement, "-webkit-animation-iteration-count", newIterationCount); | 540 | this.ninjaStylesContoller.setElementStyle(this.animatedElement, "-webkit-animation-iteration-count", newIterationCount); |
517 | 541 | ||
542 | /* Creating the animation rule */ | ||
518 | initRule = "@-webkit-keyframes " + this.animationName + " { 0% {" + this.trackEditorProperty + ": " + currentStyleValue + ";} 100% {" + this.trackEditorProperty + ": " + currentStyleValue + ";} }"; | 543 | initRule = "@-webkit-keyframes " + this.animationName + " { 0% {" + this.trackEditorProperty + ": " + currentStyleValue + ";} 100% {" + this.trackEditorProperty + ": " + currentStyleValue + ";} }"; |
519 | this.currentKeyframeRule = this.ninjaStylesContoller.addRule(initRule); | 544 | this.currentKeyframeRule = this.ninjaStylesContoller.addRule(initRule); |
520 | this.insertPropTween(tweenEvent.offsetX); | 545 | this.insertPropTween(tweenEvent.offsetX); |