diff options
author | Kruti Shah | 2012-07-10 09:55:55 -0700 |
---|---|---|
committer | Kruti Shah | 2012-07-10 09:55:55 -0700 |
commit | 7b32af1ebeec13f4186ba0a88a6d33362178d60f (patch) | |
tree | 91feeeab486e33937613e6e7d1b11991eee42631 /js/panels/Timeline/PropertyTrack.reel/PropertyTrack.js | |
parent | ba1341b82d51a5380e7dd2dc91aef76caf635e60 (diff) | |
download | ninja-7b32af1ebeec13f4186ba0a88a6d33362178d60f.tar.gz |
Adding Zoom Control to Property Tracks
Signed-off-by: Kruti Shah <kruti.shah@motorola.com>
Diffstat (limited to 'js/panels/Timeline/PropertyTrack.reel/PropertyTrack.js')
-rw-r--r-- | js/panels/Timeline/PropertyTrack.reel/PropertyTrack.js | 42 |
1 files changed, 41 insertions, 1 deletions
diff --git a/js/panels/Timeline/PropertyTrack.reel/PropertyTrack.js b/js/panels/Timeline/PropertyTrack.reel/PropertyTrack.js index b2683d30..8c8112ad 100644 --- a/js/panels/Timeline/PropertyTrack.reel/PropertyTrack.js +++ b/js/panels/Timeline/PropertyTrack.reel/PropertyTrack.js | |||
@@ -192,6 +192,7 @@ var PropertyTrack = exports.PropertyTrack = Montage.create(Component, { | |||
192 | this.trackID = this.timelineTrack.trackID; | 192 | this.trackID = this.timelineTrack.trackID; |
193 | this.animatedElement = this.timelineTrack.animatedElement; | 193 | this.animatedElement = this.timelineTrack.animatedElement; |
194 | this.ninjaStylesContoller = this.application.ninja.stylesController; | 194 | this.ninjaStylesContoller = this.application.ninja.stylesController; |
195 | this.eventManager.addEventListener("tlZoomSlider", this, false); | ||
195 | } | 196 | } |
196 | }, | 197 | }, |
197 | 198 | ||
@@ -274,6 +275,45 @@ var PropertyTrack = exports.PropertyTrack = Montage.create(Component, { | |||
274 | } | 275 | } |
275 | }, | 276 | }, |
276 | 277 | ||
278 | handleTlZoomSlider: { | ||
279 | value: function(event) { | ||
280 | |||
281 | var currentMilliSecPerPixel , currentMilliSec , clickPos,thingToPush; | ||
282 | var i = 0, | ||
283 | tweensLength = this.propTweens.length; | ||
284 | |||
285 | for (i = 0; i < tweensLength; i++) { | ||
286 | |||
287 | if (i === 0) { | ||
288 | // Exception: 0th item does not depend on anything | ||
289 | // If 0th tween is draggable, this will need to be fixed. | ||
290 | this.propTweens[i].tweenData.spanWidth=0; | ||
291 | this.propTweens[i].tweenData.spanPosition=0; | ||
292 | this.propTweens[i].tweenData.keyFramePosition=0; | ||
293 | this.propTweens[i].tweenData.keyFrameMillisec=0; | ||
294 | |||
295 | } else { | ||
296 | var prevKeyFramePosition = this.propTweens[i - 1].tweenData.keyFramePosition, | ||
297 | myObj = {}, | ||
298 | thing = {}; | ||
299 | |||
300 | currentMilliSecPerPixel = Math.floor(this.application.ninja.timeline.millisecondsOffset / 80); | ||
301 | currentMilliSec = this.propTweens[i].tweenData.keyFrameMillisec; | ||
302 | clickPos = currentMilliSec / currentMilliSecPerPixel; | ||
303 | |||
304 | for (thing in this.propTweens[i].tweenData) { | ||
305 | myObj[thing] = this.propTweens[i].tweenData[thing]; | ||
306 | } | ||
307 | myObj.spanWidth = clickPos - prevKeyFramePosition; | ||
308 | myObj.keyFramePosition = clickPos; | ||
309 | myObj.spanPosition = clickPos - (clickPos - prevKeyFramePosition); | ||
310 | |||
311 | this.propTweens[i].tweenData = myObj; | ||
312 | } | ||
313 | } | ||
314 | } | ||
315 | }, | ||
316 | |||
277 | /* End: Event Handlers */ | 317 | /* End: Event Handlers */ |
278 | 318 | ||
279 | /* Begin: Controllers */ | 319 | /* Begin: Controllers */ |
@@ -303,7 +343,7 @@ var PropertyTrack = exports.PropertyTrack = Montage.create(Component, { | |||
303 | newTween; | 343 | newTween; |
304 | 344 | ||
305 | selectedIndex = this.application.ninja.timeline.getLayerIndexByID(this.trackID); | 345 | selectedIndex = this.application.ninja.timeline.getLayerIndexByID(this.trackID); |
306 | this.application.ninja.timeline.selectLayer(selectedIndex, true); | 346 | this.application.ninja.timeline.selectLayers([selectedIndex]); |
307 | 347 | ||
308 | currentMillisecPerPixel = Math.floor(this.application.ninja.timeline.millisecondsOffset / 80); | 348 | currentMillisecPerPixel = Math.floor(this.application.ninja.timeline.millisecondsOffset / 80); |
309 | currentMillisec = currentMillisecPerPixel * clickPos; | 349 | currentMillisec = currentMillisecPerPixel * clickPos; |