PageRenderTime 89ms CodeModel.GetById 18ms RepoModel.GetById 1ms app.codeStats 0ms

/src/uncompressed/TweenMax.js

https://github.com/AnxietyDesign/Greensock
JavaScript | 4682 lines | 3987 code | 496 blank | 199 comment | 1549 complexity | 3eb5d8aab3b6e0270f99ba8d514be45d MD5 | raw file
  1. /**
  2. * VERSION: beta 1.542
  3. * DATE: 2012-10-01
  4. * JavaScript (ActionScript 3 and 2 also available)
  5. * UPDATES AND DOCS AT: http://www.greensock.com
  6. *
  7. * Includes all of the following: TweenLite, TweenMax, TimelineLite, TimelineMax, easing.EasePack, plugins.CSSPlugin, plugins.RoundPropsPlugin, plugins.BezierPlugin
  8. *
  9. * Copyright (c) 2008-2012, GreenSock. All rights reserved.
  10. * This work is subject to the terms in http://www.greensock.com/terms_of_use.html or for
  11. * Club GreenSock members, the software agreement that was issued with your membership.
  12. *
  13. * @author: Jack Doyle, jack@greensock.com
  14. **/
  15. (window._gsQueue || (window._gsQueue = [])).push( function() {
  16. /*
  17. * ----------------------------------------------------------------
  18. * TweenMax
  19. * ----------------------------------------------------------------
  20. */
  21. _gsDefine("TweenMax", ["core.Animation","core.SimpleTimeline","TweenLite"], function(Animation, SimpleTimeline, TweenLite) {
  22. var TweenMax = function(target, duration, vars) {
  23. TweenLite.call(this, target, duration, vars);
  24. this._cycle = 0;
  25. this._yoyo = (this.vars.yoyo == true);
  26. this._repeat = this.vars.repeat || 0;
  27. this._repeatDelay = this.vars.repeatDelay || 0;
  28. this._dirty = true; //ensures that if there is any repeat, the totalDuration will get recalculated to accurately report it.
  29. },
  30. p = TweenMax.prototype = TweenLite.to({}, 0.1, {}),
  31. _blankArray = [];
  32. p.constructor = TweenMax;
  33. p.kill()._gc = false;
  34. TweenMax.killTweensOf = TweenMax.killDelayedCallsTo = TweenLite.killTweensOf;
  35. TweenMax.getTweensOf = TweenLite.getTweensOf;
  36. TweenMax.ticker = TweenLite.ticker;
  37. p.invalidate = function() {
  38. this._yoyo = (this.vars.yoyo == true);
  39. this._repeat = this.vars.repeat || 0;
  40. this._repeatDelay = this.vars.repeatDelay || 0;
  41. this._uncache(true);
  42. return TweenLite.prototype.invalidate.call(this);
  43. };
  44. p.updateTo = function(vars, resetDuration) {
  45. var curRatio = this.ratio, p;
  46. if (resetDuration) if (this.timeline != null) if (this._startTime < this._timeline._time) {
  47. this._startTime = this._timeline._time;
  48. this._uncache(false);
  49. if (this._gc) {
  50. this._enabled(true, false);
  51. } else {
  52. this._timeline.insert(this, this._startTime - this._delay); //ensures that any necessary re-sequencing of Animations in the timeline occurs to make sure the rendering order is correct.
  53. }
  54. }
  55. for (p in vars) {
  56. this.vars[p] = vars[p];
  57. }
  58. if (this._initted) {
  59. if (resetDuration) {
  60. this._initted = false;
  61. } else {
  62. if (this._notifyPluginsOfEnabled && this._firstPT) {
  63. TweenLite._onPluginEvent("_onDisable", this); //in case a plugin like MotionBlur must perform some cleanup tasks
  64. }
  65. if (this._time / this._duration > 0.998) { //if the tween has finished (or come extremely close to finishing), we just need to rewind it to 0 and then render it again at the end which forces it to re-initialize (parsing the new vars). We allow tweens that are close to finishing (but haven't quite finished) to work this way too because otherwise, the values are so small when determining where to project the starting values that binary math issues creep in and can make the tween appear to render incorrectly when run backwards.
  66. var prevTime = this._time;
  67. this.render(0, true, false);
  68. this._initted = false;
  69. this.render(prevTime, true, false);
  70. } else if (this._time > 0) {
  71. this._initted = false;
  72. this._init();
  73. var inv = 1 / (1 - curRatio),
  74. pt = this._firstPT, endValue;
  75. while (pt) {
  76. endValue = pt.s + pt.c;
  77. pt.c *= inv;
  78. pt.s = endValue - pt.c;
  79. pt = pt._next;
  80. }
  81. }
  82. }
  83. }
  84. return this;
  85. };
  86. p.render = function(time, suppressEvents, force) {
  87. var totalDur = (!this._dirty) ? this._totalDuration : this.totalDuration(),
  88. prevTime = this._time,
  89. prevTotalTime = this._totalTime,
  90. prevCycle = this._cycle,
  91. isComplete, callback, pt;
  92. if (time >= totalDur) {
  93. this._totalTime = totalDur;
  94. this._cycle = this._repeat;
  95. if (this._yoyo && (this._cycle & 1) !== 0) {
  96. this._time = 0;
  97. this.ratio = this._ease._calcEnd ? this._ease.getRatio(0) : 0;
  98. } else {
  99. this._time = this._duration;
  100. this.ratio = this._ease._calcEnd ? this._ease.getRatio(1) : 1;
  101. }
  102. if (!this._reversed) {
  103. isComplete = true;
  104. callback = "onComplete";
  105. }
  106. if (this._duration === 0) { //zero-duration tweens are tricky because we must discern the momentum/direction of time in order to determine whether the starting values should be rendered or the ending values. If the "playhead" of its timeline goes past the zero-duration tween in the forward direction or lands directly on it, the end values should be rendered, but if the timeline's "playhead" moves past it in the backward direction (from a postitive time to a negative time), the starting values must be rendered.
  107. if (time === 0 || this._rawPrevTime < 0) if (this._rawPrevTime !== time) {
  108. force = true;
  109. }
  110. this._rawPrevTime = time;
  111. }
  112. } else if (time <= 0) {
  113. this._totalTime = this._time = this._cycle = 0;
  114. this.ratio = this._ease._calcEnd ? this._ease.getRatio(0) : 0;
  115. if (prevTotalTime !== 0 || (this._duration === 0 && this._rawPrevTime > 0)) {
  116. callback = "onReverseComplete";
  117. isComplete = this._reversed;
  118. }
  119. if (time < 0) {
  120. this._active = false;
  121. if (this._duration === 0) { //zero-duration tweens are tricky because we must discern the momentum/direction of time in order to determine whether the starting values should be rendered or the ending values. If the "playhead" of its timeline goes past the zero-duration tween in the forward direction or lands directly on it, the end values should be rendered, but if the timeline's "playhead" moves past it in the backward direction (from a postitive time to a negative time), the starting values must be rendered.
  122. if (this._rawPrevTime >= 0) {
  123. force = true;
  124. }
  125. this._rawPrevTime = time;
  126. }
  127. } else if (!this._initted) { //if we render the very beginning (time == 0) of a fromTo(), we must force the render (normal tweens wouldn't need to render at a time of 0 when the prevTime was also 0). This is also mandatory to make sure overwriting kicks in immediately.
  128. force = true;
  129. }
  130. } else {
  131. this._totalTime = this._time = time;
  132. if (this._repeat !== 0) {
  133. var cycleDuration = this._duration + this._repeatDelay;
  134. this._cycle = (this._totalTime / cycleDuration) >> 0; //originally _totalTime % cycleDuration but floating point errors caused problems, so I normalized it. (4 % 0.8 should be 0 but Flash reports it as 0.79999999!)
  135. if (this._cycle !== 0) if (this._cycle === this._totalTime / cycleDuration) {
  136. this._cycle--; //otherwise when rendered exactly at the end time, it will act as though it is repeating (at the beginning)
  137. }
  138. this._time = this._totalTime - (this._cycle * cycleDuration);
  139. if (this._yoyo) if ((this._cycle & 1) !== 0) {
  140. this._time = this._duration - this._time;
  141. }
  142. if (this._time > this._duration) {
  143. this._time = this._duration;
  144. } else if (this._time < 0) {
  145. this._time = 0;
  146. }
  147. }
  148. if (this._easeType) {
  149. var r = this._time / this._duration,
  150. type = this._easeType,
  151. pow = this._easePower;
  152. if (type === 1 || (type === 3 && r >= 0.5)) {
  153. r = 1 - r;
  154. }
  155. if (type === 3) {
  156. r *= 2;
  157. }
  158. if (pow === 1) {
  159. r *= r;
  160. } else if (pow === 2) {
  161. r *= r * r;
  162. } else if (pow === 3) {
  163. r *= r * r * r;
  164. } else if (pow === 4) {
  165. r *= r * r * r * r;
  166. }
  167. if (type === 1) {
  168. this.ratio = 1 - r;
  169. } else if (type === 2) {
  170. this.ratio = r;
  171. } else if (this._time / this._duration < 0.5) {
  172. this.ratio = r / 2;
  173. } else {
  174. this.ratio = 1 - (r / 2);
  175. }
  176. } else {
  177. this.ratio = this._ease.getRatio(this._time / this._duration);
  178. }
  179. }
  180. if (prevTime === this._time && !force) {
  181. return;
  182. } else if (!this._initted) {
  183. this._init();
  184. if (!isComplete && this._time) { //_ease is initially set to defaultEase, so now that init() has run, _ease is set properly and we need to recalculate the ratio. Overall this is faster than using conditional logic earlier in the method to avoid having to set ratio twice because we only init() once but renderTime() gets called VERY frequently.
  185. this.ratio = this._ease.getRatio(this._time / this._duration);
  186. }
  187. }
  188. if (!this._active) if (!this._paused) {
  189. this._active = true; //so that if the user renders a tween (as opposed to the timeline rendering it), the timeline is forced to re-render and align it with the proper time/frame on the next rendering cycle. Maybe the tween already finished but the user manually re-renders it as halfway done.
  190. }
  191. if (prevTotalTime == 0) if (this.vars.onStart) if (this._totalTime !== 0 || this._duration === 0) if (!suppressEvents) {
  192. this.vars.onStart.apply(this.vars.onStartScope || this, this.vars.onStartParams || _blankArray);
  193. }
  194. pt = this._firstPT;
  195. while (pt) {
  196. if (pt.f) {
  197. pt.t[pt.p](pt.c * this.ratio + pt.s);
  198. } else {
  199. pt.t[pt.p] = pt.c * this.ratio + pt.s;
  200. }
  201. pt = pt._next;
  202. }
  203. if (this._onUpdate) if (!suppressEvents) {
  204. this._onUpdate.apply(this.vars.onUpdateScope || this, this.vars.onUpdateParams || _blankArray);
  205. }
  206. if (this._cycle != prevCycle) if (!suppressEvents) if (!this._gc) if (this.vars.onRepeat) {
  207. this.vars.onRepeat.apply(this.vars.onRepeatScope || this, this.vars.onRepeatParams || _blankArray);
  208. }
  209. if (callback) if (!this._gc) { //check gc because there's a chance that kill() could be called in an onUpdate
  210. if (isComplete) {
  211. if (this._timeline.autoRemoveChildren) {
  212. this._enabled(false, false);
  213. }
  214. this._active = false;
  215. }
  216. if (!suppressEvents) if (this.vars[callback]) {
  217. this.vars[callback].apply(this.vars[callback + "Scope"] || this, this.vars[callback + "Params"] || _blankArray);
  218. }
  219. }
  220. };
  221. //---- STATIC FUNCTIONS -----------------------------------------------------------------------------------------------------------
  222. TweenMax.to = function(target, duration, vars) {
  223. return new TweenMax(target, duration, vars);
  224. };
  225. TweenMax.from = function(target, duration, vars) {
  226. vars.runBackwards = true;
  227. if (vars.immediateRender != false) {
  228. vars.immediateRender = true;
  229. }
  230. return new TweenMax(target, duration, vars);
  231. };
  232. TweenMax.fromTo = function(target, duration, fromVars, toVars) {
  233. toVars.startAt = fromVars;
  234. if (fromVars.immediateRender) {
  235. toVars.immediateRender = true;
  236. }
  237. return new TweenMax(target, duration, toVars);
  238. };
  239. TweenMax.staggerTo = TweenMax.allTo = function(targets, duration, vars, stagger, onCompleteAll, onCompleteAllParams, onCompleteAllScope) {
  240. stagger = stagger || 0;
  241. var a = [],
  242. l = targets.length,
  243. delay = vars.delay || 0,
  244. copy, i, p;
  245. for (i = 0; i < l; i++) {
  246. copy = {};
  247. for (p in vars) {
  248. copy[p] = vars[p];
  249. }
  250. copy.delay = delay;
  251. if (i === l - 1) if (onCompleteAll) {
  252. copy.onComplete = function() {
  253. if (vars.onComplete) {
  254. vars.onComplete.apply(vars.onCompleteScope, vars.onCompleteParams);
  255. }
  256. onCompleteAll.apply(onCompleteAllScope, onCompleteAllParams);
  257. }
  258. }
  259. a[i] = new TweenMax(targets[i], duration, copy);
  260. delay += stagger;
  261. }
  262. return a;
  263. };
  264. TweenMax.staggerFrom = TweenMax.allFrom = function(targets, duration, vars, stagger, onCompleteAll, onCompleteAllParams, onCompleteAllScope) {
  265. vars.runBackwards = true;
  266. if (vars.immediateRender != false) {
  267. vars.immediateRender = true;
  268. }
  269. return TweenMax.staggerTo(targets, duration, vars, stagger, onCompleteAll, onCompleteAllParams, onCompleteAllScope);
  270. };
  271. TweenMax.staggerFromTo = TweenMax.allFromTo = function(targets, duration, fromVars, toVars, stagger, onCompleteAll, onCompleteAllParams, onCompleteAllScope) {
  272. toVars.startAt = fromVars;
  273. if (fromVars.immediateRender) {
  274. toVars.immediateRender = true;
  275. }
  276. return TweenMax.staggerTo(targets, duration, toVars, stagger, onCompleteAll, onCompleteAllParams, onCompleteAllScope);
  277. };
  278. TweenMax.delayedCall = function(delay, callback, params, scope, useFrames) {
  279. return new TweenMax(callback, 0, {delay:delay, onComplete:callback, onCompleteParams:params, onCompleteScope:scope, onReverseComplete:callback, onReverseCompleteParams:params, onReverseCompleteScope:scope, immediateRender:false, useFrames:useFrames, overwrite:0});
  280. };
  281. TweenMax.set = function(target, vars) {
  282. return new TweenMax(target, 0, vars);
  283. };
  284. TweenMax.isTweening = function(target) {
  285. var a = TweenLite.getTweensOf(target),
  286. i = a.length,
  287. tween;
  288. while (--i > -1) {
  289. if (((tween = a[i])._active || (tween._startTime === tween.timeline._time && tween.timeline._active))) {
  290. return true;
  291. }
  292. }
  293. return false;
  294. };
  295. var _getChildrenOf = function(timeline, includeTimelines) {
  296. var a = [],
  297. cnt = 0,
  298. tween = timeline._first;
  299. while (tween) {
  300. if (tween instanceof TweenLite) {
  301. a[cnt++] = tween;
  302. } else {
  303. if (includeTimelines) {
  304. a[cnt++] = tween;
  305. }
  306. a = a.concat(_getChildrenOf(tween, includeTimelines));
  307. cnt = a.length;
  308. }
  309. tween = tween._next;
  310. }
  311. return a;
  312. },
  313. getAllTweens = TweenMax.getAllTweens = function(includeTimelines) {
  314. var a = _getChildrenOf(Animation._rootTimeline, includeTimelines);
  315. return a.concat( _getChildrenOf(Animation._rootFramesTimeline, includeTimelines) );
  316. };
  317. TweenMax.killAll = function(complete, tweens, delayedCalls, timelines) {
  318. if (tweens == null) {
  319. tweens = true;
  320. }
  321. if (delayedCalls == null) {
  322. delayedCalls = true;
  323. }
  324. var a = getAllTweens((timelines != false)),
  325. l = a.length,
  326. allTrue = (tweens && delayedCalls && timelines),
  327. isDC, tween, i;
  328. for (i = 0; i < l; i++) {
  329. tween = a[i];
  330. if (allTrue || (tween instanceof SimpleTimeline) || ((isDC = (tween.target === tween.vars.onComplete)) && delayedCalls) || (tweens && !isDC)) {
  331. if (complete) {
  332. tween.totalTime(tween.totalDuration());
  333. } else {
  334. tween._enabled(false, false);
  335. }
  336. }
  337. }
  338. };
  339. TweenMax.killChildTweensOf = function(parent, complete) {
  340. if (parent == null) {
  341. return;
  342. }
  343. if (parent.jquery) {
  344. parent.each( function(i, e) {
  345. TweenMax.killChildTweensOf(e, complete);
  346. });
  347. return;
  348. }
  349. var tl = TweenLite._tweenLookup,
  350. a = [],
  351. target, curParent, p, i, l;
  352. for (p in tl) {
  353. curParent = tl[p].target.parentNode;
  354. while (curParent) {
  355. if (curParent === parent) {
  356. a = a.concat(tl[p].tweens);
  357. }
  358. curParent = curParent.parentNode;
  359. }
  360. }
  361. l = a.length;
  362. for (i = 0; i < l; i++) {
  363. if (complete) {
  364. a[i].totalTime(a[i].totalDuration());
  365. }
  366. a[i]._enabled(false, false);
  367. }
  368. };
  369. TweenMax.pauseAll = function(tweens, delayedCalls, timelines) {
  370. _changePause(true, tweens, delayedCalls, timelines);
  371. };
  372. TweenMax.resumeAll = function(tweens, delayedCalls, timelines) {
  373. _changePause(false, tweens, delayedCalls, timelines);
  374. };
  375. var _changePause = function(pause, tweens, delayedCalls, timelines) {
  376. if (tweens == undefined) {
  377. tweens = true;
  378. }
  379. if (delayedCalls == undefined) {
  380. delayedCalls = true;
  381. }
  382. var a = getAllTweens(timelines),
  383. allTrue = (tweens && delayedCalls && timelines),
  384. i = a.length,
  385. isDC, tween;
  386. while (--i > -1) {
  387. tween = a[i];
  388. if (allTrue || (tween instanceof SimpleTimeline) || ((isDC = (tween.target === tween.vars.onComplete)) && delayedCalls) || (tweens && !isDC)) {
  389. tween.paused(pause);
  390. }
  391. }
  392. };
  393. //---- GETTERS / SETTERS ----------------------------------------------------------------------------------------------------------
  394. p.progress = function(value) {
  395. return (!arguments.length) ? this._time / this.duration() : this.totalTime( this.duration() * value + (this._cycle * this._duration), false);
  396. };
  397. p.totalProgress = function(value) {
  398. return (!arguments.length) ? this._totalTime / this.totalDuration() : this.totalTime( this.totalDuration() * value, false);
  399. };
  400. p.time = function(value, suppressEvents) {
  401. if (!arguments.length) {
  402. return this._time;
  403. }
  404. if (this._dirty) {
  405. this.totalDuration();
  406. }
  407. if (value > this._duration) {
  408. value = this._duration;
  409. }
  410. if (this._yoyo && (this._cycle & 1) !== 0) {
  411. value = (this._duration - value) + (this._cycle * (this._duration + this._repeatDelay));
  412. } else if (this._repeat != 0) {
  413. value += this._cycle * (this._duration + this._repeatDelay);
  414. }
  415. return this.totalTime(value, suppressEvents);
  416. };
  417. p.totalDuration = function(value) {
  418. if (!arguments.length) {
  419. if (this._dirty) {
  420. //instead of Infinity, we use 999999999999 so that we can accommodate reverses
  421. this._totalDuration = (this._repeat === -1) ? 999999999999 : this._duration * (this._repeat + 1) + (this._repeatDelay * this._repeat);
  422. this._dirty = false;
  423. }
  424. return this._totalDuration;
  425. }
  426. return (this._repeat == -1) ? this : this.duration( (value - (this._repeat * this._repeatDelay)) / (this._repeat + 1) );
  427. };
  428. p.repeat = function(value) {
  429. if (!arguments.length) {
  430. return this._repeat;
  431. }
  432. this._repeat = value;
  433. return this._uncache(true);
  434. };
  435. p.repeatDelay = function(value) {
  436. if (!arguments.length) {
  437. return this._repeatDelay;
  438. }
  439. this._repeatDelay = value;
  440. return this._uncache(true);
  441. };
  442. p.yoyo = function(value) {
  443. if (!arguments.length) {
  444. return this._yoyo;
  445. }
  446. this._yoyo = value;
  447. return this;
  448. };
  449. return TweenMax;
  450. }, true);
  451. /*
  452. * ----------------------------------------------------------------
  453. * TimelineLite (!TimelineLite)
  454. * ----------------------------------------------------------------
  455. */
  456. _gsDefine("TimelineLite", ["core.Animation","core.SimpleTimeline","TweenLite"], function(Animation, SimpleTimeline, TweenLite) {
  457. "use strict";
  458. var TimelineLite = function(vars) {
  459. SimpleTimeline.call(this, vars);
  460. this._labels = {};
  461. this.autoRemoveChildren = (this.vars.autoRemoveChildren == true);
  462. this.smoothChildTiming = (this.vars.smoothChildTiming == true);
  463. this._sortChildren = true;
  464. this._onUpdate = this.vars.onUpdate;
  465. var i = _paramProps.length,
  466. j, a;
  467. while (--i > -1) {
  468. if ((a = this.vars[_paramProps[i]])) {
  469. j = a.length;
  470. while (--j > -1) {
  471. if (a[j] === "{self}") {
  472. a = this.vars[_paramProps[i]] = a.concat(); //copy the array in case the user referenced the same array in multiple timelines/tweens (each {self} should be unique)
  473. a[j] = this;
  474. }
  475. }
  476. }
  477. }
  478. if (this.vars.tweens instanceof Array) {
  479. this.insertMultiple(this.vars.tweens, 0, this.vars.align || "normal", this.vars.stagger || 0);
  480. }
  481. },
  482. _paramProps = ["onStartParams","onUpdateParams","onCompleteParams","onReverseCompleteParams","onRepeatParams"],
  483. _blankArray = [],
  484. _copy = function(vars) {
  485. var copy = {}, p;
  486. for (p in vars) {
  487. copy[p] = vars[p];
  488. }
  489. return copy;
  490. },
  491. p = TimelineLite.prototype = new SimpleTimeline();
  492. p.constructor = TimelineLite;
  493. p.kill()._gc = false;
  494. p.to = function(target, duration, vars, offset, baseTimeOrLabel) {
  495. return this.insert( new TweenLite(target, duration, vars), this._parseTimeOrLabel(baseTimeOrLabel) + (offset || 0));
  496. }
  497. p.from = function(target, duration, vars, offset, baseTimeOrLabel) {
  498. return this.insert( TweenLite.from(target, duration, vars), this._parseTimeOrLabel(baseTimeOrLabel) + (offset || 0));
  499. }
  500. p.fromTo = function(target, duration, fromVars, toVars, offset, baseTimeOrLabel) {
  501. return this.insert( TweenLite.fromTo(target, duration, fromVars, toVars), this._parseTimeOrLabel(baseTimeOrLabel) + (offset || 0));
  502. }
  503. p.staggerTo = function(targets, duration, vars, stagger, offset, baseTimeOrLabel, onCompleteAll, onCompleteAllParams, onCompleteAllScope) {
  504. var tl = new TimelineLite({onComplete:onCompleteAll, onCompleteParams:onCompleteAllParams, onCompleteScope:onCompleteAllScope});
  505. stagger = stagger || 0;
  506. for (var i = 0; i < targets.length; i++) {
  507. if (vars.startAt != null) {
  508. vars.startAt = _copy(vars.startAt);
  509. }
  510. tl.insert( new TweenLite(targets[i], duration, _copy(vars)), i * stagger);
  511. }
  512. return this.insert(tl, this._parseTimeOrLabel(baseTimeOrLabel) + (offset || 0));
  513. }
  514. p.staggerFrom = function(targets, duration, vars, stagger, offset, baseTimeOrLabel, onCompleteAll, onCompleteAllParams, onCompleteAllScope) {
  515. if (vars.immediateRender == null) {
  516. vars.immediateRender = true;
  517. }
  518. vars.runBackwards = true;
  519. return this.staggerTo(targets, duration, vars, stagger, offset, baseTimeOrLabel, onCompleteAll, onCompleteAllParams, onCompleteAllScope);
  520. }
  521. p.staggerFromTo = function(targets, duration, fromVars, toVars, stagger, offset, baseTimeOrLabel, onCompleteAll, onCompleteAllParams, onCompleteAllScope) {
  522. toVars.startAt = fromVars;
  523. if (fromVars.immediateRender) {
  524. toVars.immediateRender = true;
  525. }
  526. return this.staggerTo(targets, duration, toVars, stagger, offset, baseTimeOrLabel, onCompleteAll, onCompleteAllParams, onCompleteAllScope);
  527. }
  528. p.call = function(callback, params, scope, offset, baseTimeOrLabel) {
  529. return this.insert( TweenLite.delayedCall(0, callback, params, scope), this._parseTimeOrLabel(baseTimeOrLabel) + (offset || 0));
  530. }
  531. p.set = function(target, vars, offset, baseTimeOrLabel) {
  532. vars.immediateRender = false;
  533. return this.insert( new TweenLite(target, 0, vars), this._parseTimeOrLabel(baseTimeOrLabel) + (offset || 0));
  534. }
  535. TimelineLite.exportRoot = function(vars, ignoreDelayedCalls) {
  536. vars = vars || {};
  537. if (vars.smoothChildTiming == null) {
  538. vars.smoothChildTiming = true;
  539. }
  540. var tl = new TimelineLite(vars),
  541. root = tl._timeline;
  542. if (ignoreDelayedCalls == null) {
  543. ignoreDelayedCalls = true;
  544. }
  545. root._remove(tl, true);
  546. tl._startTime = 0;
  547. tl._rawPrevTime = tl._time = tl._totalTime = root._time;
  548. var tween = root._first, next;
  549. while (tween) {
  550. next = tween._next;
  551. if (!ignoreDelayedCalls || !(tween instanceof TweenLite && tween.target == tween.vars.onComplete)) {
  552. tl.insert(tween, tween._startTime - tween._delay);
  553. }
  554. tween = next;
  555. }
  556. root.insert(tl, 0);
  557. return tl;
  558. }
  559. p.insert = function(value, timeOrLabel) {
  560. if (value instanceof Animation) {
  561. //continue...
  562. } else if (value instanceof Array) {
  563. return this.insertMultiple(value, timeOrLabel);
  564. } else if (typeof(value) === "string") {
  565. return this.addLabel(value, this._parseTimeOrLabel(timeOrLabel || 0, true));
  566. } else if (typeof(value) === "function") {
  567. value = TweenLite.delayedCall(0, value);
  568. } else {
  569. throw ("ERROR: Cannot insert() " + value + " into the TimelineLite/Max because it is neither a tween, timeline, function, nor a String.");
  570. return this;
  571. }
  572. SimpleTimeline.prototype.insert.call(this, value, this._parseTimeOrLabel(timeOrLabel || 0, true));
  573. //if the timeline has already ended but the inserted tween/timeline extends the duration, we should enable this timeline again so that it renders properly.
  574. if (this._gc) if (!this._paused) if (this._time === this._duration) if (this._time < this.duration()) {
  575. //in case any of the anscestors had completed but should now be enabled...
  576. var tl = this;
  577. while (tl._gc && tl._timeline) {
  578. if (tl._timeline.smoothChildTiming) {
  579. tl.totalTime(tl._totalTime, true); //also enables them
  580. } else {
  581. tl._enabled(true, false);
  582. }
  583. tl = tl._timeline;
  584. }
  585. }
  586. return this;
  587. }
  588. p.remove = function(value) {
  589. if (value instanceof Animation) {
  590. return this._remove(value, false);
  591. } else if (value instanceof Array) {
  592. var i = value.length;
  593. while (--i > -1) {
  594. this.remove(value[i]);
  595. }
  596. return this;
  597. } else if (typeof(value) === "string") {
  598. return this.removeLabel(value);
  599. }
  600. return this.kill(null, value);
  601. }
  602. p.append = function(value, offset) {
  603. return this.insert(value, this.duration() + (offset || 0));
  604. }
  605. p.insertMultiple = function(tweens, timeOrLabel, align, stagger) {
  606. align = align || "normal";
  607. stagger = stagger || 0;
  608. var i, tween, curTime = this._parseTimeOrLabel(timeOrLabel || 0, true), l = tweens.length;
  609. for (i = 0; i < l; i++) {
  610. if ((tween = tweens[i]) instanceof Array) {
  611. tween = new TimelineLite({tweens:tween});
  612. }
  613. this.insert(tween, curTime);
  614. if (typeof(tween) === "string" || typeof(tween) === "function") {
  615. //do nothing
  616. } else if (align === "sequence") {
  617. curTime = tween._startTime + (tween.totalDuration() / tween._timeScale);
  618. } else if (align === "start") {
  619. tween._startTime -= tween.delay();
  620. }
  621. curTime += stagger;
  622. }
  623. return this._uncache(true);
  624. }
  625. p.appendMultiple = function(tweens, offset, align, stagger) {
  626. return this.insertMultiple(tweens, this.duration() + (offset || 0), align, stagger);
  627. }
  628. p.addLabel = function(label, time) {
  629. this._labels[label] = time;
  630. return this;
  631. }
  632. p.removeLabel = function(label) {
  633. delete this._labels[label];
  634. return this;
  635. }
  636. p.getLabelTime = function(label) {
  637. return (this._labels[label] != null) ? this._labels[label] : -1;
  638. }
  639. p._parseTimeOrLabel = function(timeOrLabel, appendIfAbsent) {
  640. if (timeOrLabel == null) {
  641. return this.duration();
  642. } else if (typeof(timeOrLabel) === "string" && isNaN(timeOrLabel)) {
  643. if (this._labels[timeOrLabel] == null) {
  644. return (appendIfAbsent) ? (this._labels[timeOrLabel] = this.duration()) : 0;
  645. }
  646. return this._labels[timeOrLabel];
  647. }
  648. return Number(timeOrLabel);
  649. }
  650. p.seek = function(timeOrLabel, suppressEvents) {
  651. return this.totalTime(this._parseTimeOrLabel(timeOrLabel, false), (suppressEvents != false));
  652. }
  653. p.stop = function() {
  654. return this.paused(true);
  655. }
  656. p.gotoAndPlay = function(timeOrLabel, suppressEvents) {
  657. return SimpleTimeline.prototype.play.call(this, timeOrLabel, suppressEvents);
  658. }
  659. p.gotoAndStop = function(timeOrLabel, suppressEvents) {
  660. return this.pause(timeOrLabel, suppressEvents);
  661. }
  662. p.render = function(time, suppressEvents, force) {
  663. if (this._gc) {
  664. this._enabled(true, false);
  665. }
  666. this._active = !this._paused;
  667. var totalDur = (!this._dirty) ? this._totalDuration : this.totalDuration(),
  668. prevTime = this._time,
  669. prevStart = this._startTime,
  670. prevTimeScale = this._timeScale,
  671. prevPaused = this._paused,
  672. tween, isComplete, next, callback;
  673. if (time >= totalDur) {
  674. this._totalTime = this._time = totalDur;
  675. if (!this._reversed) if (!this._hasPausedChild()) {
  676. isComplete = true;
  677. callback = "onComplete";
  678. if (this._duration === 0) if (time === 0 || this._rawPrevTime < 0) if (this._rawPrevTime !== time) { //In order to accommodate zero-duration timelines, we must discern the momentum/direction of time in order to render values properly when the "playhead" goes past 0 in the forward direction or lands directly on it, and also when it moves past it in the backward direction (from a postitive time to a negative time).
  679. force = true;
  680. }
  681. }
  682. this._rawPrevTime = time;
  683. time = totalDur + 0.000001; //to avoid occassional floating point rounding errors - sometimes child tweens/timelines were not being fully completed (their progress might be 0.999999999999998 instead of 1 because when _time - tween._startTime is performed, floating point errors would return a value that was SLIGHTLY off)
  684. } else if (time <= 0) {
  685. this._totalTime = this._time = 0;
  686. if (prevTime !== 0 || (this._duration === 0 && this._rawPrevTime > 0)) {
  687. callback = "onReverseComplete";
  688. isComplete = this._reversed;
  689. }
  690. if (time < 0) {
  691. this._active = false;
  692. if (this._duration === 0) if (this._rawPrevTime >= 0) { //zero-duration timelines are tricky because we must discern the momentum/direction of time in order to determine whether the starting values should be rendered or the ending values. If the "playhead" of its timeline goes past the zero-duration tween in the forward direction or lands directly on it, the end values should be rendered, but if the timeline's "playhead" moves past it in the backward direction (from a postitive time to a negative time), the starting values must be rendered.
  693. force = true;
  694. }
  695. } else if (!this._initted) {
  696. force = true;
  697. }
  698. this._rawPrevTime = time;
  699. time = -0.000001; //to avoid occassional floating point rounding errors in Flash - sometimes child tweens/timelines were not being rendered at the very beginning (their progress might be 0.000000000001 instead of 0 because when Flash performed _time - tween._startTime, floating point errors would return a value that was SLIGHTLY off)
  700. } else {
  701. this._totalTime = this._time = this._rawPrevTime = time;
  702. }
  703. if (this._time === prevTime && !force) {
  704. return;
  705. } else if (!this._initted) {
  706. this._initted = true;
  707. }
  708. if (prevTime === 0) if (this.vars.onStart) if (this._time !== 0) if (!suppressEvents) {
  709. this.vars.onStart.apply(this.vars.onStartScope || this, this.vars.onStartParams || _blankArray);
  710. }
  711. if (this._time > prevTime) {
  712. tween = this._first;
  713. while (tween) {
  714. next = tween._next; //record it here because the value could change after rendering...
  715. if (this._paused && !prevPaused) { //in case a tween pauses the timeline when rendering
  716. break;
  717. } else if (tween._active || (tween._startTime <= this._time && !tween._paused && !tween._gc)) {
  718. if (!tween._reversed) {
  719. tween.render((time - tween._startTime) * tween._timeScale, suppressEvents, false);
  720. } else {
  721. tween.render(((!tween._dirty) ? tween._totalDuration : tween.totalDuration()) - ((time - tween._startTime) * tween._timeScale), suppressEvents, false);
  722. }
  723. }
  724. tween = next;
  725. }
  726. } else {
  727. tween = this._last;
  728. while (tween) {
  729. next = tween._prev; //record it here because the value could change after rendering...
  730. if (this._paused && !prevPaused) { //in case a tween pauses the timeline when rendering
  731. break;
  732. } else if (tween._active || (tween._startTime <= prevTime && !tween._paused && !tween._gc)) {
  733. if (!tween._reversed) {
  734. tween.render((time - tween._startTime) * tween._timeScale, suppressEvents, false);
  735. } else {
  736. tween.render(((!tween._dirty) ? tween._totalDuration : tween.totalDuration()) - ((time - tween._startTime) * tween._timeScale), suppressEvents, false);
  737. }
  738. }
  739. tween = next;
  740. }
  741. }
  742. if (this._onUpdate) if (!suppressEvents) {
  743. this._onUpdate.apply(this.vars.onUpdateScope || this, this.vars.onUpdateParams || _blankArray);
  744. }
  745. if (callback) if (!this._gc) if (prevStart === this._startTime || prevTimeScale != this._timeScale) if (this._time === 0 || totalDur >= this.totalDuration()) { //if one of the tweens that was rendered altered this timeline's startTime (like if an onComplete reversed the timeline), it probably isn't complete. If it is, don't worry, because whatever call altered the startTime would complete if it was necessary at the new time. The only exception is the timeScale property. Also check _gc because there's a chance that kill() could be called in an onUpdate
  746. if (isComplete) {
  747. if (this._timeline.autoRemoveChildren) {
  748. this._enabled(false, false);
  749. }
  750. this._active = false;
  751. }
  752. if (!suppressEvents) if (this.vars[callback]) {
  753. this.vars[callback].apply(this.vars[callback + "Scope"] || this, this.vars[callback + "Params"] || _blankArray);
  754. }
  755. }
  756. }
  757. p._hasPausedChild = function() {
  758. var tween = this._first;
  759. while (tween) {
  760. if (tween._paused || ((tween instanceof TimelineLite) && tween._hasPausedChild())) {
  761. return true;
  762. }
  763. tween = tween._next;
  764. }
  765. return false;
  766. }
  767. p.getChildren = function(nested, tweens, timelines, ignoreBeforeTime) {
  768. ignoreBeforeTime = ignoreBeforeTime || -9999999999;
  769. var a = [],
  770. tween = this._first,
  771. cnt = 0;
  772. while (tween) {
  773. if (tween._startTime < ignoreBeforeTime) {
  774. //do nothing
  775. } else if (tween instanceof TweenLite) {
  776. if (tweens != false) {
  777. a[cnt++] = tween;
  778. }
  779. } else {
  780. if (timelines != false) {
  781. a[cnt++] = tween;
  782. }
  783. if (nested != false) {
  784. a = a.concat(tween.getChildren(true, tweens, timelines));
  785. cnt = a.length;
  786. }
  787. }
  788. tween = tween._next;
  789. }
  790. return a;
  791. }
  792. p.getTweensOf = function(target, nested) {
  793. var tweens = TweenLite.getTweensOf(target),
  794. i = tweens.length,
  795. a = [],
  796. cnt = 0;
  797. while (--i > -1) {
  798. if (tweens[i].timeline === this || (nested && this._contains(tweens[i]))) {
  799. a[cnt++] = tweens[i];
  800. }
  801. }
  802. return a;
  803. }
  804. p._contains = function(tween) {
  805. var tl = tween.timeline;
  806. while (tl) {
  807. if (tl === this) {
  808. return true;
  809. }
  810. tl = tl.timeline;
  811. }
  812. return false;
  813. }
  814. p.shiftChildren = function(amount, adjustLabels, ignoreBeforeTime) {
  815. ignoreBeforeTime = ignoreBeforeTime || 0;
  816. var tween = this._first;
  817. while (tween) {
  818. if (tween._startTime >= ignoreBeforeTime) {
  819. tween._startTime += amount;
  820. }
  821. tween = tween._next;
  822. }
  823. if (adjustLabels) {
  824. for (var p in this._labels) {
  825. if (this._labels[p] >= ignoreBeforeTime) {
  826. this._labels[p] += amount;
  827. }
  828. }
  829. }
  830. return this._uncache(true);
  831. }
  832. p._kill = function(vars, target) {
  833. if (vars == null) if (target == null) {
  834. return this._enabled(false, false);
  835. }
  836. var tweens = (target == null) ? this.getChildren(true, true, false) : this.getTweensOf(target),
  837. i = tweens.length,
  838. changed = false;
  839. while (--i > -1) {
  840. if (tweens[i]._kill(vars, target)) {
  841. changed = true;
  842. }
  843. }
  844. return changed;
  845. }
  846. p.clear = function(labels) {
  847. var tweens = this.getChildren(false, true, true),
  848. i = tweens.length;
  849. this._time = this._totalTime = 0;
  850. while (--i > -1) {
  851. tweens[i]._enabled(false, false);
  852. }
  853. if (labels != false) {
  854. this._labels = {};
  855. }
  856. return this._uncache(true);
  857. }
  858. p.invalidate = function() {
  859. var tween = this._first;
  860. while (tween) {
  861. tween.invalidate();
  862. tween = tween._next;
  863. }
  864. return this;
  865. }
  866. p._enabled = function(enabled, ignoreTimeline) {
  867. if (enabled == this._gc) {
  868. var tween = this._first;
  869. while (tween) {
  870. tween._enabled(enabled, true);
  871. tween = tween._next;
  872. }
  873. }
  874. return SimpleTimeline.prototype._enabled.call(this, enabled, ignoreTimeline);
  875. }
  876. p.progress = function(value) {
  877. return (!arguments.length) ? this._time / this.duration() : this.totalTime(this.duration() * value, false);
  878. }
  879. p.duration = function(value) {
  880. if (!arguments.length) {
  881. if (this._dirty) {
  882. this.totalDuration(); //just triggers recalculation
  883. }
  884. return this._duration;
  885. }
  886. if (this.duration() !== 0) if (value !== 0) {
  887. this.timeScale(this._duration / value);
  888. }
  889. return this;
  890. }
  891. p.totalDuration = function(value) {
  892. if (!arguments.length) {
  893. if (this._dirty) {
  894. var max = 0,
  895. tween = this._first,
  896. prevStart = -999999999999,
  897. next, end;
  898. while (tween) {
  899. next = tween._next; //record it here in case the tween changes position in the sequence...
  900. if (tween._startTime < prevStart && this._sortChildren) { //in case one of the tweens shifted out of order, it needs to be re-inserted into the correct position in the sequence
  901. this.insert(tween, tween._startTime - tween._delay);
  902. } else {
  903. prevStart = tween._startTime;
  904. }
  905. if (tween._startTime < 0) {//children aren't allowed to have negative startTimes, so adjust here if one is found.
  906. max -= tween._startTime;
  907. this.shiftChildren(-tween._startTime, false, -9999999999);
  908. }
  909. end = tween._startTime + ((!tween._dirty ? tween._totalDuration : tween.totalDuration()) / tween._timeScale);
  910. if (end > max) {
  911. max = end;
  912. }
  913. tween = next;
  914. }
  915. this._duration = this._totalDuration = max;
  916. this._dirty = false;
  917. }
  918. return this._totalDuration;
  919. }
  920. if (this.totalDuration() !== 0) if (value !== 0) {
  921. this.timeScale(this._totalDuration / value);
  922. }
  923. return this;
  924. }
  925. p.usesFrames = function() {
  926. var tl = this._timeline;
  927. while (tl._timeline) {
  928. tl = tl._timeline;
  929. }
  930. return (tl === Animation._rootFramesTimeline);
  931. }
  932. p.rawTime = function() {
  933. return (this._paused || (this._totalTime !== 0 && this._totalTime !== this._totalDuration)) ? this._totalTime : (this._timeline.rawTime() - this._startTime) * this._timeScale;
  934. }
  935. return TimelineLite;
  936. }, true);
  937. /*
  938. * ----------------------------------------------------------------
  939. * TimelineMax
  940. * ----------------------------------------------------------------
  941. */
  942. _gsDefine("TimelineMax", ["TimelineLite","TweenLite","easing.Ease"], function(TimelineLite, TweenLite, Ease) {
  943. var TimelineMax = function(vars) {
  944. TimelineLite.call(this, vars);
  945. this._repeat = this.vars.repeat || 0;
  946. this._repeatDelay = this.vars.repeatDelay || 0;
  947. this._cycle = 0;
  948. this._yoyo = (this.vars.yoyo == true);
  949. this._dirty = true;
  950. },
  951. _blankArray = [],
  952. _easeNone = new Ease(null, null, 1, 0),
  953. _getGlobalPaused = function(tween) {
  954. while (tween) {
  955. if (tween._paused) {
  956. return true;
  957. }
  958. tween = tween._timeline;
  959. }
  960. return false;
  961. },
  962. p = TimelineMax.prototype = new TimelineLite();
  963. p.constructor = TimelineMax;
  964. p.kill()._gc = false;
  965. TimelineMax.version = 12.0;
  966. p.invalidate = function() {
  967. this._yoyo = (this.vars.yoyo == true);
  968. this._repeat = this.vars.repeat || 0;
  969. this._repeatDelay = this.vars.repeatDelay || 0;
  970. this._uncache(true);
  971. return TimelineLite.prototype.invalidate.call(this);
  972. }
  973. p.addCallback = function(callback, timeOrLabel, params, scope) {
  974. return this.insert( TweenLite.delayedCall(0, callback, params, scope), timeOrLabel);
  975. }
  976. p.removeCallback = function(callback, timeOrLabel) {
  977. if (timeOrLabel == null) {
  978. this._kill(null, callback);
  979. } else {
  980. var a = this.getTweensOf(callback, false),
  981. i = a.length,
  982. time = this._parseTimeOrLabel(timeOrLabel, false);
  983. while (--i > -1) {
  984. if (a[i]._startTime === time) {
  985. a[i]._enabled(false, false);
  986. }
  987. }
  988. }
  989. return this;
  990. }
  991. p.tweenTo = function(timeOrLabel, vars) {
  992. vars = vars || {};
  993. var copy = {ease:_easeNone, overwrite:2, useFrames:this.usesFrames(), immediateRender:false}, p, t;
  994. for (p in vars) {
  995. copy[p] = vars[p];
  996. }
  997. copy.time = this._parseTimeOrLabel(timeOrLabel, false);
  998. t = new TweenLite(this, (Math.abs(Number(copy.time) - this._time) / this._timeScale) || 0.001, copy);
  999. copy.onStart = function() {
  1000. t.target.paused(true);
  1001. if (t.vars.time != t.target.time()) { //don't make the duration zero - if it's supposed to be zero, don't worry because it's already initting the tween and will complete immediately, effectively making the duration zero anyway. If we make duration zero, the tween won't run at all.
  1002. t.duration( Math.abs( t.vars.time - t.target.time()) / t.target._timeScale );
  1003. }
  1004. if (vars.onStart) { //in case the user had an onStart in the vars - we don't want to overwrite it.
  1005. vars.onStart.apply(vars.onStartScope || t, vars.onStartParams || _blankArray);
  1006. }
  1007. }
  1008. return t;
  1009. }
  1010. p.tweenFromTo = function(fromTimeOrLabel, toTimeOrLabel, vars) {
  1011. vars = vars || {};
  1012. vars.startAt = {time:this._parseTimeOrLabel(fromTimeOrLabel, false)};
  1013. var t = this.tweenTo(toTimeOrLabel, vars);
  1014. return t.duration((Math.abs( t.vars.time - t.vars.startAt.time) / this._timeScale) || 0.001);
  1015. }
  1016. p.render = function(time, suppressEvents, force) {
  1017. if (this._gc) {
  1018. this._enabled(true, false);
  1019. }
  1020. this._active = !this._paused;
  1021. var totalDur = (!this._dirty) ? this._totalDuration : this.totalDuration(),
  1022. prevTime = this._time,
  1023. prevTotalTime = this._totalTime,
  1024. prevStart = this._startTime,
  1025. prevTimeScale = this._timeScale,
  1026. prevRawPrevTime = this._rawPrevTime,
  1027. prevPaused = this._paused,
  1028. prevCycle = this._cycle,
  1029. tween, isComplete, next, dur, callback;
  1030. if (time >= totalDur) {
  1031. if (!this._locked) {
  1032. this._totalTime = totalDur;
  1033. this._cycle = this._repeat;
  1034. }
  1035. if (!this._reversed) if (!this._hasPausedChild()) {
  1036. isComplete = true;
  1037. callback = "onComplete";
  1038. if (this._duration === 0) if (time === 0 || this._rawPrevTime < 0) if (this._rawPrevTime !== time) { //In order to accommodate zero-duration timelines, we must discern the momentum/direction of time in order to render values properly when the "playhead" goes past 0 in the forward direction or lands directly on it, and also when it moves past it in the backward direction (from a postitive time to a negative time).
  1039. force = true;
  1040. }
  1041. }
  1042. this._rawPrevTime = time;
  1043. if (this._yoyo && (this._cycle & 1) !== 0) {
  1044. this._time = 0;
  1045. time = -0.000001; //to avoid occassional floating point rounding errors - sometimes child tweens/timelines were not being rendered at the very beginning (their progress might be 0.000000000001 instead of 0 because when Flash performed _time - tween._startTime, floating point errors would return a value that was SLIGHTLY off)
  1046. } else {
  1047. this._time = this._duration;
  1048. time = this._duration + 0.000001; //to avoid occassional floating point rounding errors in Flash - sometimes child tweens/timelines were not being fully completed (their progress might be 0.999999999999998 instead of 1 because when Flash performed _time - tween._startTime, floating point errors would return a value that was SLIGHTLY off)
  1049. }
  1050. } else if (time <= 0) {
  1051. if (!this._locked) {
  1052. this._totalTime = this._cycle = 0;
  1053. }
  1054. this._time = 0;
  1055. if (prevTime !== 0 || (this._duration === 0 && this._rawPrevTime > 0)) {
  1056. callback = "onReverseComplete";
  1057. isComplete = this._reversed;
  1058. }
  1059. if (time < 0) {
  1060. this._active = false;
  1061. if (this._duration === 0) if (this._rawPrevTime >= 0) { //zero-duration timelines are tricky because we must discern the momentum/direction of time in order to determine whether the starting values should be rendered or the ending values. If the "playhead" of its timeline goes past the zero-duration tween in the forward direction or lands directly on it, the end values should be rendered, but if the timeline's "playhead" moves past it in the backward direction (from a postitive time to a negative time), the starting values must be rendered.
  1062. force = true;
  1063. }
  1064. } else if (!this._initted) {
  1065. force = true;
  1066. }
  1067. this._rawPrevTime = time;
  1068. time = -0.000001; //to avoid occassional floating point rounding errors in Flash - sometimes child tweens/timelines were not being rendered at the very beginning (their progress might be 0.000000000001 instead of 0 because when Flash performed _time - tween._startTime, floating point errors would return a value that was SLIGHTLY off)
  1069. } else {
  1070. this._time = this._rawPrevTime = time;
  1071. if (!this._locked) {
  1072. this._totalTime = time;
  1073. if (this._repeat !== 0) {
  1074. var cycleDuration = this._duration + this._repeatDelay;
  1075. this._cycle = (this._totalTime / cycleDuration) >> 0; //originally _totalTime % cycleDuration but floating point errors caused problems, so I normalized it. (4 % 0.8 should be 0 but Flash reports it as 0.79999999!)
  1076. if (this._cycle !== 0) if (this._cycle === this._totalTime / cycleDuration) {
  1077. this._cycle--; //otherwise when rendered exactly at the end time, it will act as though it is repeating (at the beginning)
  1078. }
  1079. this._time = this._totalTime - (this._cycle * cycleDuration);
  1080. if (this._yoyo) if ((this._cycle & 1) != 0) {
  1081. this._time = this._duration - this._time;
  1082. }
  1083. if (this._time > this._duration) {
  1084. this._time = this._duration;
  1085. time = this._duration + 0.000001; //to avoid occassional floating point rounding errors in Flash - sometimes child tweens/timelines were not being fully completed (their progress might be 0.999999999999998 instead of 1 because when Flash performed _time - tween._startTime, floating point errors would return a value that was SLIGHTLY off)
  1086. } else if (this._time < 0) {
  1087. this._time = 0;
  1088. time = -0.000001; //to avoid occassional floating point rounding errors in Flash - sometimes child tweens/timelines were not being rendered at the very beginning (their progress might be 0.000000000001 instead of 0 because when Flash performed _time - tween._startTime, floating point errors would return a value that was SLIGHTLY off)
  1089. } else {
  1090. time = this._time;
  1091. }
  1092. }
  1093. }
  1094. }
  1095. if (this._cycle !== prevCycle) if (!this._locked) {
  1096. /*
  1097. make sure children at the end/beginning of the timeline are rendered properly. If, for example,
  1098. a 3-second long timeline rendered at 2.9 seconds previously, and now renders at 3.2 seconds (which
  1099. would get transated to 2.8 seconds if the timeline yoyos or 0.2 seconds if it just repeats), there
  1100. could be a callback or a short tween that's at 2.95 or 3 seconds in which wouldn't render. So
  1101. we need to push the timeline to the end (and/or beginning depending on its yoyo value). Also we must
  1102. ensure that zero-duration tweens at the very beginning or end of the TimelineMax work.
  1103. */
  1104. var backwards = (this._yoyo && (prevCycle & 1) !== 0),
  1105. wrap = (backwards === (this._yoyo && (this._cycle & 1) !== 0)),
  1106. recTotalTime = this._totalTime,
  1107. recCycle = this._cycle,
  1108. recRawPrevTime = this._rawPrevTime,
  1109. recTime = this._time;
  1110. this._totalTime = prevCycle * this._duration;
  1111. if (this._cycle < prevCycle) {
  1112. backwards = !backwards;
  1113. } else {
  1114. this._totalTime += this._duration;
  1115. }
  1116. this._time = prevTime; //temporarily revert _time so that render() renders the children in the correct order. Without this, tweens won't rewind correctly. We could arhictect things in a "cleaner" way by splitting out the rendering queue into a separate method but for performance reasons, we kept it all inside this method.
  1117. this._rawPrevTime = prevRawPrevTime;
  1118. this._cycle = prevCycle;
  1119. this._locked = true; //prevents changes to totalTime and skips repeat/yoyo behavior when we recursively call render()
  1120. prevTime = (backwards) ? 0 : this._duration;
  1121. this.render(prevTime, suppressEvents, false);
  1122. if (!suppressEvents) if (!this._gc) {
  1123. if (this.vars.onRepeat) {
  1124. this.vars.onRepeat.apply(this.vars.onRepeatScope || this, this.vars.onRepeatParams || _blankArray);
  1125. }
  1126. }
  1127. if (wrap) {
  1128. prevTime = (backwards) ? this._duration + 0.000001 : -0.000001;
  1129. this.render(prevTime, true, false);
  1130. }
  1131. this._time = recTime;
  1132. this._totalTime = recTotalTime;
  1133. this._cycle = recCycle;
  1134. this._rawPrevTime = recRawPrevTime;
  1135. this._locked = false;
  1136. }
  1137. if (this._time === prevTime && !force) {
  1138. return;
  1139. } else if (!this._initted) {
  1140. this._initted = true;
  1141. }
  1142. if (prevTotalTime === 0) if (this.vars.onStart) if (this._totalTime !== 0) if (!suppressEvents) {
  1143. this.vars.onStart.apply(this.vars.onStartScope || this, this.vars.onStartParams || _blankArray);
  1144. }
  1145. if (this._time > prevTime) {
  1146. tween = this._first;
  1147. while (tween) {
  1148. next = tween._next; //record it here because the value could change after rendering...
  1149. if (this._paused && !prevPaused) { //in case a tween pauses the timeline when rendering
  1150. break;
  1151. } else if (tween._active || (tween._startTime <= this._time && !tween._paused && !tween._gc)) {
  1152. if (!tween._reversed) {
  1153. tween.render((time - tween._startTime) * tween._timeScale, suppressEvents, false);
  1154. } else {
  1155. tween.render(((!tween._dirty) ? tween._totalDuration : tween.totalDuration()) - ((time - tween._startTime) * tween._timeScale), suppressEvents, false);
  1156. }
  1157. }
  1158. tween = next;
  1159. }
  1160. } else {
  1161. tween = this._last;
  1162. while (tween) {
  1163. next = tween._prev; //record it here because the value could change after rendering...
  1164. if (this._paused && !prevPaused) { //in case a tween pauses the timeline when rendering
  1165. break;
  1166. } else if (tween._active || (tween._startTime <= prevTime && !tween._paused && !tween._gc)) {
  1167. if (!tween._reversed) {
  1168. tween.render((time - tween._startTime) * tween._timeScale, suppressEvents, false);
  1169. } else {
  1170. tween.render(((!tween._dirty) ? tween._totalDuration : tween.totalDuration()) - ((time - tween._startTime) * tween._timeScale), suppressEvents, false);
  1171. }
  1172. }
  1173. tween = next;
  1174. }
  1175. }
  1176. if (this._onUpdate) if (!suppressEvents) {
  1177. this._onUpdate.apply(this.vars.onUpdateScope || this, this.vars.onUpdateParams || _blankArray);
  1178. }
  1179. if (callback) if (!this._locked) if (!this._gc) if (prevStart === this._startTime || prevTimeScale != this._timeScale) if (this._time === 0 || totalDur >= this.totalDuration()) { //if one of the tweens that was rendered altered this timeline's startTime (like if an onComplete reversed the timeline), it probably isn't complete. If it is, don't worry, because whatever call altered the startTime would complete if it was necessary at the new time. The only exception is the timeScale property. Also check _gc because there's a chance that kill() could be called in an onUpdate
  1180. if (isComplete) {
  1181. if (this._timeline.autoRemoveChildren) {
  1182. this._enabled(false, false);
  1183. }
  1184. this._active = false;
  1185. }
  1186. if (!suppressEvents) if (this.vars[callback]) {
  1187. this.vars[callback].apply(this.vars[callback + "Scope"] || this, this.vars[callback + "Params"] || _blankArray);
  1188. }
  1189. }
  1190. }
  1191. p.getActive = function(nested, tweens, timelines) {
  1192. if (nested == null) {
  1193. nested = true;
  1194. }
  1195. if (tweens == null) {
  1196. tweens = true;
  1197. }
  1198. if (timelines == null) {
  1199. timelines = false;
  1200. }
  1201. var a = [],
  1202. all = this.getChildren(nested, tweens, timelines),
  1203. cnt = 0,
  1204. l = all.length,
  1205. i, tween;
  1206. for (i = 0; i < l; i++) {
  1207. tween = all[i];
  1208. //note: we cannot just check tween.active because timelines that contain paused children will continue to have "active" set to true even after the playhead passes their end point (technically a timeline can only be considered complete after all of its children have completed too, but paused tweens are...well...just waiting and until they're unpaused we don't know where their end point will be).
  1209. if (!tween._paused) if (tween._timeline._time >= tween._startTime) if (tween._timeline._time < tween._startTime + tween._totalDuration / tween._timeScale) if (!_getGlobalPaused(tween._timeline)) {
  1210. a[cnt++] = tween;
  1211. }
  1212. }
  1213. return a;
  1214. }
  1215. p.getLabelAfter = function(time) {
  1216. if (!time) if (time !== 0) { //faster than isNan()
  1217. time = this._time;
  1218. }
  1219. var labels = this.getLabelsArray(),
  1220. l = labels.length,
  1221. i;
  1222. for (i = 0; i < l; i++) {
  1223. if (labels[i].time > time) {
  1224. return labels[i].name;
  1225. }
  1226. }
  1227. return null;
  1228. }
  1229. p.getLabelBefore = function(time) {
  1230. if (time == null) {
  1231. time = this._time;
  1232. }
  1233. var labels = this.getLabelsArray(),
  1234. i = labels.length;
  1235. while (--i > -1) {
  1236. if (labels[i].time < time) {
  1237. return labels[i].name;
  1238. }
  1239. }
  1240. return null;
  1241. }
  1242. p.getLabelsArray = function() {
  1243. var a = [],
  1244. cnt = 0,
  1245. p;
  1246. for (p in this._labels) {
  1247. a[cnt++] = {time:this._labels[p], name:p};
  1248. }
  1249. a.sort(function(a,b) {
  1250. return a.time - b.time;
  1251. });
  1252. return a;
  1253. }
  1254. //---- GETTERS / SETTERS -------------------------------------------------------------------------------------------------------
  1255. p.progress = function(value) {
  1256. return (!arguments.length) ? this._time / this.duration() : this.totalTime( this.duration() * value + (this._cycle * this._duration), false);
  1257. }
  1258. p.totalProgress = function(value) {
  1259. return (!arguments.length) ? this._totalTime / this.totalDuration() : this.totalTime( this.totalDuration() * value, false);
  1260. }
  1261. p.totalDuration = function(value) {
  1262. if (!arguments.length) {
  1263. if (this._dirty) {
  1264. TimelineLite.prototype.totalDuration.call(this); //just forces refresh
  1265. //Instead of Infinity, we use 999999999999 so that we can accommodate reverses.
  1266. this._totalDuration = (this._repeat === -1) ? 999999999999 : this._duration * (this._repeat + 1) + (this._repeatDelay * this._repeat);
  1267. }
  1268. return this._totalDuration;
  1269. }
  1270. return (this._repeat == -1) ? this : this.duration( (value - (this._repeat * this._repeatDelay)) / (this._repeat + 1) );
  1271. }
  1272. p.time = function(value, suppressEvents) {
  1273. if (!arguments.length) {
  1274. return this._time;
  1275. }
  1276. if (this._dirty) {
  1277. this.totalDuration();
  1278. }
  1279. if (value > this._duration) {
  1280. value = this._duration;
  1281. }
  1282. if (this._yoyo && (this._cycle & 1) !== 0) {
  1283. value = (this._duration - value) + (this._cycle * (this._duration + this._repeatDelay));
  1284. } else if (this._repeat != 0) {
  1285. value += this._cycle * (this._duration + this._repeatDelay);
  1286. }
  1287. return this.totalTime(value, suppressEvents);
  1288. }
  1289. p.repeat = function(value) {
  1290. if (!arguments.length) {
  1291. return this._repeat;
  1292. }
  1293. this._repeat = value;
  1294. return this._uncache(true);
  1295. }
  1296. p.repeatDelay = function(value) {
  1297. if (!arguments.length) {
  1298. return this._repeatDelay;
  1299. }
  1300. this._repeatDelay = value;
  1301. return this._uncache(true);
  1302. }
  1303. p.yoyo = function(value) {
  1304. if (!arguments.length) {
  1305. return this._yoyo;
  1306. }
  1307. this._yoyo = value;
  1308. return this;
  1309. }
  1310. p.currentLabel = function(value) {
  1311. if (!arguments.length) {
  1312. return this.getLabelBefore(this._time + 0.00000001);
  1313. }
  1314. return this.seek(value, true);
  1315. }
  1316. return TimelineMax;
  1317. }, true);
  1318. /*
  1319. * ----------------------------------------------------------------
  1320. * BezierPlugin (!BezierPlugin)
  1321. * ----------------------------------------------------------------
  1322. */
  1323. _gsDefine("plugins.BezierPlugin", ["plugins.TweenPlugin"], function(TweenPlugin) {
  1324. var BezierPlugin = function(props, priority) {
  1325. TweenPlugin.call(this, "bezier", -1);
  1326. this._overwriteProps.pop();
  1327. this._func = {};
  1328. this._round = {};
  1329. },
  1330. p = BezierPlugin.prototype = new TweenPlugin("bezier", 1),
  1331. _RAD2DEG = 180 / Math.PI,
  1332. _r1 = [],
  1333. _r2 = [],
  1334. _r3 = [],
  1335. _corProps = {},
  1336. Segment = function Segment(a, b, c, d) {
  1337. this.a = a;
  1338. this.b = b;
  1339. this.c = c;
  1340. this.d = d;
  1341. this.da = d - a;
  1342. this.ca = c - a;
  1343. this.ba = b - a;
  1344. },
  1345. _correlate = ",x,y,z,left,top,right,bottom,marginTop,marginLeft,marginRight,marginBottom,paddingLeft,paddingTop,paddingRight,paddingBottom,backgroundPosition,backgroundPosition_y,",
  1346. bezierThrough = BezierPlugin.bezierThrough = function(values, curviness, quadratic, basic, correlate, prepend) {
  1347. var obj = {},
  1348. props = [],
  1349. i, p;
  1350. correlate = (typeof(correlate) === "string") ? ","+correlate+"," : _correlate;
  1351. if (curviness == null) {
  1352. curviness = 1;
  1353. }
  1354. for (p in values[0]) {
  1355. props.push(p);
  1356. }
  1357. _r1.length = _r2.length = _r3.length = 0;
  1358. i = props.length;
  1359. while (--i > -1) {
  1360. p = props[i];
  1361. _corProps[p] = (correlate.indexOf(","+p+",") !== -1);
  1362. obj[p] = _parseAnchors(values, p, _corProps[p], prepend);
  1363. }
  1364. i = _r1.length;
  1365. while (--i > -1) {
  1366. _r1[i] = Math.sqrt(_r1[i]);
  1367. _r2[i] = Math.sqrt(_r2[i]);
  1368. }
  1369. if (!basic) {
  1370. i = props.length;
  1371. while (--i > -1) {
  1372. if (_corProps[p]) {
  1373. a = obj[props[i]];
  1374. l = a.length - 1;
  1375. for (j = 0; j < l; j++) {
  1376. r = a[j+1].da / _r2[j] + a[j].da / _r1[j];
  1377. _r3[j] = (_r3[j] || 0) + r * r;
  1378. }
  1379. }
  1380. }
  1381. i = _r3.length;
  1382. while (--i > -1) {
  1383. _r3[i] = Math.sqrt(_r3[i]);
  1384. }
  1385. }
  1386. i = props.length;
  1387. while (--i > -1) {
  1388. p = props[i];
  1389. _calculateControlPoints(obj[p], curviness, quadratic, basic, _corProps[p]); //this method requires that _parseAnchors() and _setSegmentRatios() ran first so that _r1, _r2, and _r3 values are populated for all properties
  1390. }
  1391. return obj;
  1392. },
  1393. _parseBezierData = function(values, type, prepend) {
  1394. type = type || "soft";
  1395. var obj = {},
  1396. inc = (type === "cubic") ? 3 : 2,
  1397. soft = (type === "soft"),
  1398. props = [],
  1399. a, b, c, d, cur, i, j, l, p, cnt, tmp;
  1400. if (soft && prepend) {
  1401. values = [prepend].concat(values);
  1402. }
  1403. if (values == null || values.length < inc + 1) { throw "invalid Bezier data"; }
  1404. for (p in values[0]) {
  1405. props.push(p);
  1406. }
  1407. i = props.length;
  1408. while (--i > -1) {
  1409. p = props[i];
  1410. obj[p] = cur = [];
  1411. cnt = 0;
  1412. l = values.length;
  1413. for (j = 0; j < l; j++) {
  1414. a = (prepend == null) ? values[j][p] : (typeof( (tmp = values[j][p]) ) === "string" && tmp.charAt(1) === "=") ? prepend[p] + Number(tmp.charAt(0) + tmp.substr(2)) : Number(tmp);
  1415. if (soft) if (j > 1) if (j < l - 1) {
  1416. cur[cnt++] = (a + cur[cnt-2]) / 2;
  1417. }
  1418. cur[cnt++] = a;
  1419. }
  1420. l = cnt - inc + 1;
  1421. cnt = 0;
  1422. for (j = 0; j < l; j += inc) {
  1423. a = cur[j];
  1424. b = cur[j+1];
  1425. c = cur[j+2];
  1426. d = (inc === 2) ? 0 : cur[j+3];
  1427. cur[cnt++] = tmp = (inc === 3) ? new Segment(a, b, c, d) : new Segment(a, (2 * b + a) / 3, (2 * b + c) / 3, c);
  1428. }
  1429. cur.length = cnt;
  1430. }
  1431. return obj;
  1432. },
  1433. _parseAnchors = function(values, p, correlate, prepend) {
  1434. var a = [],
  1435. l, i, obj, p1, p2, p3, r1, tmp;
  1436. if (prepend) {
  1437. values = [prepend].concat(values);
  1438. i = values.length;
  1439. while (--i > -1) {
  1440. if (typeof( (tmp = values[i][p]) ) === "string") if (tmp.charAt(1) === "=") {
  1441. values[i][p] = prepend[p] + Number(tmp.charAt(0) + tmp.substr(2)); //accommodate relative values. Do it inline instead of breaking it out into a function for speed reasons
  1442. }
  1443. }
  1444. }
  1445. l = values.length - 2;
  1446. if (l < 0) {
  1447. a[0] = new Segment(values[0][p], 0, 0, values[(l < -1) ? 0 : 1][p]);
  1448. return a;
  1449. }
  1450. for (i = 0; i < l; i++) {
  1451. p1 = values[i][p];
  1452. p2 = values[i+1][p];
  1453. a[i] = new Segment(p1, 0, 0, p2);
  1454. if (correlate) {
  1455. p3 = values[i+2][p];
  1456. _r1[i] = (_r1[i] || 0) + (p2 - p1) * (p2 - p1);
  1457. _r2[i] = (_r2[i] || 0) + (p3 - p2) * (p3 - p2);
  1458. }
  1459. }
  1460. a[i] = new Segment(values[i][p], 0, 0, values[i+1][p]);
  1461. return a;
  1462. },
  1463. _calculateControlPoints = function(a, curviness, quad, basic, correlate) {
  1464. var l = a.length - 1,
  1465. ii = 0,
  1466. cp1 = a[0].a,
  1467. i, p1, p2, p3, seg, m1, m2, mm, cp2, qb, r1, r2, tl;
  1468. for (i = 0; i < l; i++) {
  1469. seg = a[ii];
  1470. p1 = seg.a;
  1471. p2 = seg.d;
  1472. p3 = a[ii+1].d;
  1473. if (correlate) {
  1474. r1 = _r1[i];
  1475. r2 = _r2[i];
  1476. tl = ((r2 + r1) * curviness * 0.25) / (basic ? 0.5 : _r3[i] || 0.5);
  1477. m1 = p2 - (p2 - p1) * (basic ? curviness * 0.5 : tl / r1);
  1478. m2 = p2 + (p3 - p2) * (basic ? curviness * 0.5 : tl / r2);
  1479. mm = p2 - (m1 + (m2 - m1) * ((r1 * 3 / (r1 + r2)) + 0.5) / 4);
  1480. } else {
  1481. m1 = p2 - (p2 - p1) * curviness * 0.5;
  1482. m2 = p2 + (p3 - p2) * curviness * 0.5;
  1483. mm = p2 - (m1 + m2) / 2;
  1484. }
  1485. m1 += mm;
  1486. m2 += mm;
  1487. seg.c = cp2 = m1;
  1488. if (i != 0) {
  1489. seg.b = cp1;
  1490. } else {
  1491. seg.b = cp1 = seg.a + (seg.c - seg.a) * 0.6; //instead of placing b on a exactly, we move it inline with c so that if the user specifies an ease like Back.easeIn or Elastic.easeIn which goes BEYOND the beginning, it will do so smoothly.
  1492. }
  1493. seg.da = p2 - p1;
  1494. seg.ca = cp2 - p1;
  1495. seg.ba = cp1 - p1;
  1496. if (quad) {
  1497. qb = cubicToQuadratic(p1, cp1, cp2, p2);
  1498. a.splice(ii, 1, qb[0], qb[1], qb[2], qb[3]);
  1499. ii += 4;
  1500. } else {
  1501. ii++;
  1502. }
  1503. cp1 = m2;
  1504. }
  1505. seg = a[ii];
  1506. seg.b = cp1;
  1507. seg.c = cp1 + (seg.d - cp1) * 0.4; //instead of placing c on d exactly, we move it inline with b so that if the user specifies an ease like Back.easeOut or Elastic.easeOut which goes BEYOND the end, it will do so smoothly.
  1508. seg.da = seg.d - seg.a;
  1509. seg.ca = seg.c - seg.a;
  1510. seg.ba = cp1 - seg.a;
  1511. if (quad) {
  1512. qb = cubicToQuadratic(seg.a, cp1, seg.c, seg.d);
  1513. a.splice(ii, 1, qb[0], qb[1], qb[2], qb[3]);
  1514. }
  1515. },
  1516. cubicToQuadratic = BezierPlugin.cubicToQuadratic = function(a, b, c, d) {
  1517. var q1 = {a:a},
  1518. q2 = {},
  1519. q3 = {},
  1520. q4 = {c:d},
  1521. mab = (a + b) / 2,
  1522. mbc = (b + c) / 2,
  1523. mcd = (c + d) / 2,
  1524. mabc = (mab + mbc) / 2,
  1525. mbcd = (mbc + mcd) / 2,
  1526. m8 = (mbcd - mabc) / 8;
  1527. q1.b = mab + (a - mab) / 4;
  1528. q2.b = mabc + m8;
  1529. q1.c = q2.a = (q1.b + q2.b) / 2;
  1530. q2.c = q3.a = (mabc + mbcd) / 2;
  1531. q3.b = mbcd - m8;
  1532. q4.b = mcd + (d - mcd) / 4;
  1533. q3.c = q4.a = (q3.b + q4.b) / 2;
  1534. return [q1, q2, q3, q4];
  1535. },
  1536. quadraticToCubic = BezierPlugin.quadraticToCubic = function(a, b, c) {
  1537. return new Segment(a, (2 * b + a) / 3, (2 * b + c) / 3, c);
  1538. },
  1539. _parseLengthData = function(obj, resolution) {
  1540. resolution = resolution >> 0 || 6;
  1541. var a = [],
  1542. lengths = [],
  1543. d = 0,
  1544. total = 0,
  1545. threshold = resolution - 1,
  1546. segments = [],
  1547. curLS = [], //current length segments array
  1548. p, i, l, index;
  1549. for (p in obj) {
  1550. _addCubicLengths(obj[p], a, resolution);
  1551. }
  1552. l = a.length;
  1553. for (i = 0; i < l; i++) {
  1554. d += Math.sqrt(a[i]);
  1555. index = i % resolution;
  1556. curLS[index] = d;
  1557. if (index === threshold) {
  1558. total += d;
  1559. index = (i / resolution) >> 0;
  1560. segments[index] = curLS;
  1561. lengths[index] = total;
  1562. d = 0;
  1563. curLS = [];
  1564. }
  1565. }
  1566. return {length:total, lengths:lengths, segments:segments};
  1567. },
  1568. _addCubicLengths = function(a, steps, resolution) {
  1569. var inc = 1 / resolution,
  1570. j = a.length,
  1571. d, d1, s, da, ca, ba, p, i, inv, bez, index;
  1572. while (--j > -1) {
  1573. bez = a[j];
  1574. s = bez.a;
  1575. da = bez.d - s;
  1576. ca = bez.c - s;
  1577. ba = bez.b - s;
  1578. d = d1 = 0;
  1579. for (i = 1; i <= resolution; i++) {
  1580. p = inc * i;
  1581. inv = 1 - p;
  1582. d = d1 - (d1 = (p * p * da + 3 * inv * (p * ca + inv * ba)) * p);
  1583. index = j * resolution + i - 1;
  1584. steps[index] = (steps[index] || 0) + d * d;
  1585. }
  1586. }
  1587. };
  1588. p.constructor = BezierPlugin;
  1589. BezierPlugin.API = 2;
  1590. p._onInitTween = function(target, vars, tween) {
  1591. this._target = target;
  1592. if (vars instanceof Array) {
  1593. vars = {values:vars};
  1594. }
  1595. this._props = [];
  1596. this._timeRes = (vars.timeResolution == null) ? 6 : parseInt(vars.timeResolution);
  1597. var values = vars.values || [],
  1598. first = {},
  1599. second = values[0],
  1600. autoRotate = vars.autoRotate || tween.vars.orientToBezier,
  1601. p, isFunc, i, j, prepend;
  1602. this._autoRotate = autoRotate ? (autoRotate instanceof Array) ? autoRotate : [["x","y","rotation",((autoRotate === true) ? 0 : Number(autoRotate) || 0)]] : null;
  1603. for (p in second) {
  1604. this._props.push(p);
  1605. }
  1606. i = this._props.length;
  1607. while (--i > -1) {
  1608. p = this._props[i];
  1609. this._overwriteProps.push(p);
  1610. isFunc = this._func[p] = (typeof(target[p]) === "function");
  1611. first[p] = (!isFunc) ? parseFloat(target[p]) : target[ ((p.indexOf("set") || typeof(target["get" + p.substr(3)]) !== "function") ? p : "get" + p.substr(3)) ]();
  1612. if (!prepend) if (first[p] !== values[0][p]) {
  1613. prepend = first;
  1614. }
  1615. }
  1616. this._beziers = (vars.type !== "cubic" && vars.type !== "quadratic" && vars.type !== "soft") ? bezierThrough(values, isNaN(vars.curviness) ? 1 : vars.curviness, false, (vars.type === "thruBasic"), vars.correlate, prepend) : _parseBezierData(values, vars.type, first);
  1617. this._segCount = this._beziers[p].length;
  1618. if (this._timeRes) {
  1619. var ld = _parseLengthData(this._beziers, this._timeRes);
  1620. this._length = ld.length;
  1621. this._lengths = ld.lengths;
  1622. this._segments = ld.segments;
  1623. this._l1 = this._li = this._s1 = this._si = 0;
  1624. this._l2 = this._lengths[0];
  1625. this._curSeg = this._segments[0];
  1626. this._s2 = this._curSeg[0];
  1627. this._prec = 1 / this._curSeg.length;
  1628. }
  1629. if ((autoRotate = this._autoRotate)) {
  1630. if (!(autoRotate[0] instanceof Array)) {
  1631. this._autoRotate = autoRotate = [autoRotate];
  1632. }
  1633. i = autoRotate.length;
  1634. while (--i > -1) {
  1635. for (j = 0; j < 3; j++) {
  1636. p = autoRotate[i][j];
  1637. this._func[p] = (typeof(target[p]) === "function") ? target[ ((p.indexOf("set") || typeof(target["get" + p.substr(3)]) !== "function") ? p : "get" + p.substr(3)) ] : false;
  1638. }
  1639. }
  1640. }
  1641. return true;
  1642. }
  1643. //gets called every time the tween updates, passing the new ratio (typically a value between 0 and 1, but not always (for example, if an Elastic.easeOut is used, the value can jump above 1 mid-tween). It will always start and 0 and end at 1.
  1644. p.setRatio = function(v) {
  1645. var segments = this._segCount,
  1646. func = this._func,
  1647. target = this._target,
  1648. curIndex, inv, i, p, b, t, val, l, lengths, curSeg;
  1649. if (!this._timeRes) {
  1650. curIndex = (v < 0) ? 0 : (v >= 1) ? segments - 1 : (segments * v) >> 0;
  1651. t = (v - (curIndex * (1 / segments))) * segments;
  1652. } else {
  1653. lengths = this._lengths;
  1654. curSeg = this._curSeg;
  1655. v *= this._length;
  1656. i = this._li;
  1657. //find the appropriate segment (if the currently cached one isn't correct)
  1658. if (v > this._l2 && i < segments - 1) {
  1659. l = segments - 1;
  1660. while (i < l && (this._l2 = lengths[++i]) <= v) { }
  1661. this._l1 = lengths[i-1];
  1662. this._li = i;
  1663. this._curSeg = curSeg = this._segments[i];
  1664. this._s2 = curSeg[(this._s1 = this._si = 0)];
  1665. } else if (v < this._l1 && i > 0) {
  1666. while (i > 0 && (this._l1 = lengths[--i]) >= v) { }
  1667. if (i === 0 && v < this._l1) {
  1668. this._l1 = 0;
  1669. } else {
  1670. i++;
  1671. }
  1672. this._l2 = lengths[i];
  1673. this._li = i;
  1674. this._curSeg = curSeg = this._segments[i];
  1675. this._s1 = curSeg[(this._si = curSeg.length - 1) - 1] || 0;
  1676. this._s2 = curSeg[this._si];
  1677. }
  1678. curIndex = i;
  1679. //now find the appropriate sub-segment (we split it into the number of pieces that was defined by "precision" and measured each one)
  1680. v -= this._l1;
  1681. i = this._si;
  1682. if (v > this._s2 && i < curSeg.length - 1) {
  1683. l = curSeg.length - 1;
  1684. while (i < l && (this._s2 = curSeg[++i]) <= v) { }
  1685. this._s1 = curSeg[i-1];
  1686. this._si = i;
  1687. } else if (v < this._s1 && i > 0) {
  1688. while (i > 0 && (this._s1 = curSeg[--i]) >= v) { }
  1689. if (i === 0 && v < this._s1) {
  1690. this._s1 = 0;
  1691. } else {
  1692. i++;
  1693. }
  1694. this._s2 = curSeg[i];
  1695. this._si = i;
  1696. }
  1697. t = (i + (v - this._s1) / (this._s2 - this._s1)) * this._prec;
  1698. }
  1699. inv = 1 - t;
  1700. i = this._props.length;
  1701. while (--i > -1) {
  1702. p = this._props[i];
  1703. b = this._beziers[p][curIndex];
  1704. val = (t * t * b.da + 3 * inv * (t * b.ca + inv * b.ba)) * t + b.a;
  1705. if (this._round[p]) {
  1706. val = (val + ((val > 0) ? 0.5 : -0.5)) >> 0;
  1707. }
  1708. if (func[p]) {
  1709. target[p](val);
  1710. } else {
  1711. target[p] = val;
  1712. }
  1713. }
  1714. if (this._autoRotate) {
  1715. var ar = this._autoRotate,
  1716. b2, x1, y1, x2, y2, add, conv;
  1717. i = ar.length;
  1718. while (--i > -1) {
  1719. p = ar[i][2];
  1720. add = ar[i][3] || 0;
  1721. conv = (ar[i][4] == true) ? 1 : _RAD2DEG;
  1722. b = this._beziers[ar[i][0]][curIndex];
  1723. b2 = this._beziers[ar[i][1]][curIndex];
  1724. x1 = b.a + (b.b - b.a) * t;
  1725. x2 = b.b + (b.c - b.b) * t;
  1726. x1 += (x2 - x1) * t;
  1727. x2 += ((b.c + (b.d - b.c) * t) - x2) * t;
  1728. y1 = b2.a + (b2.b - b2.a) * t;
  1729. y2 = b2.b + (b2.c - b2.b) * t;
  1730. y1 += (y2 - y1) * t;
  1731. y2 += ((b2.c + (b2.d - b2.c) * t) - y2) * t;
  1732. val = Math.atan2(y2 - y1, x2 - x1) * conv + add;
  1733. if (func[p]) {
  1734. func[p].call(target, val);
  1735. } else {
  1736. target[p] = val;
  1737. }
  1738. }
  1739. }
  1740. }
  1741. p._roundProps = function(lookup, value) {
  1742. var op = this._overwriteProps,
  1743. i = op.length;
  1744. while (--i > -1) {
  1745. if (lookup[op[i]] || lookup.bezier || lookup.bezierThrough) {
  1746. this._round[op[i]] = value;
  1747. }
  1748. }
  1749. }
  1750. p._kill = function(lookup) {
  1751. var a = this._props,
  1752. p, i;
  1753. for (p in _beziers) {
  1754. if (p in lookup) {
  1755. delete this._beziers[p];
  1756. delete this._func[p];
  1757. i = a.length;
  1758. while (--i > -1) {
  1759. if (a[i] === p) {
  1760. a.splice(i, 1);
  1761. }
  1762. }
  1763. }
  1764. }
  1765. return TweenPlugin.prototype._kill.call(this, lookup);
  1766. }
  1767. TweenPlugin.activate([BezierPlugin]);
  1768. return BezierPlugin;
  1769. }, true);
  1770. /*
  1771. * ----------------------------------------------------------------
  1772. * CSSPlugin (!CSSPlugin)
  1773. * ----------------------------------------------------------------
  1774. */
  1775. _gsDefine("plugins.CSSPlugin", ["plugins.TweenPlugin","TweenLite"], function(TweenPlugin, TweenLite) {
  1776. "use strict";
  1777. var CSSPlugin = function() {
  1778. TweenPlugin.call(this, "css");
  1779. this._overwriteProps.pop();
  1780. },
  1781. p = CSSPlugin.prototype = new TweenPlugin("css");
  1782. p.constructor = CSSPlugin;
  1783. CSSPlugin.API = 2;
  1784. CSSPlugin.suffixMap = {top:"px", right:"px", bottom:"px", left:"px", width:"px", height:"px", fontSize:"px", padding:"px", margin:"px"};
  1785. //set up some local variables and functions that we can reuse for all tweens - we do this only once and cache things to improve performance
  1786. var _NaNExp = /[^\d\-\.]/g,
  1787. _suffixExp = /(\d|\-|\+|=|#|\.)*/g,
  1788. _numExp = /(\d|\.)+/g,
  1789. _opacityExp = /opacity *= *([^)]*)/,
  1790. _opacityValExp = /opacity:([^;]*)/,
  1791. _capsExp = /([A-Z])/g,
  1792. _camelExp = /-([a-z])/gi,
  1793. _camelFunc = function(s, g) { return g.toUpperCase(); },
  1794. _horizExp = /(Left|Right|Width)/i,
  1795. _ieGetMatrixExp = /(M11|M12|M21|M22)=[\d\-\.e]+/gi,
  1796. _ieSetMatrixExp = /progid\:DXImageTransform\.Microsoft\.Matrix\(.+?\)/i,
  1797. _DEG2RAD = Math.PI / 180,
  1798. _RAD2DEG = 180 / Math.PI,
  1799. _forcePT = {},
  1800. _doc = document,
  1801. _tempDiv = _doc.createElement("div"),
  1802. _agent = navigator.userAgent,
  1803. _autoRound,
  1804. _reqSafariFix, //we won't apply the Safari transform fix until we actually come across a tween that affects a transform property (to maintain best performance).
  1805. _isSafari, //Safari (and Android 4 which uses a flavor of Safari) has a bug that prevents changes to "top" and "left" properties from rendering properly if changed on the same frame as a transform UNLESS we set the element's WebkitBackfaceVisibility to hidden (weird, I know). Doing this for Android 3 and earlier seems to actually cause other problems, though (fun!)
  1806. _ieVers,
  1807. _supportsOpacity = (function() { //we set _isSafari, _ieVers, and _supportsOpacity all in one function here to reduce file size slightly, especially in the minified version.
  1808. var i = _agent.indexOf("Android"),
  1809. d = _doc.createElement("div"), a;
  1810. _isSafari = (_agent.indexOf("Safari") !== -1 && _agent.indexOf("Chrome") === -1 && (i === -1 || Number(_agent.substr(i+8, 1)) > 3));
  1811. (/MSIE ([0-9]{1,}[\.0-9]{0,})/).exec(_agent);
  1812. _ieVers = parseFloat( RegExp.$1 );
  1813. d.innerHTML = "<a style='top:1px;opacity:.55;'>a</a>";
  1814. a = d.getElementsByTagName("a")[0];
  1815. return a ? /^0.55/.test(a.style.opacity) : false;
  1816. })(),
  1817. //parses a color (like #9F0, #FF9900, or rgb(255,51,153)) into an array with 3 elements for red, green, and blue. Also handles rgba() values (splits into array of 4 elements of course)
  1818. _parseColor = function(v) {
  1819. if (!v || v === "") {
  1820. return _colorLookup.black;
  1821. } else if (_colorLookup[v]) {
  1822. return _colorLookup[v];
  1823. } else if (typeof(v) === "number") {
  1824. return [v >> 16, (v >> 8) & 255, v & 255];
  1825. } else if (v.charAt(0) === "#") {
  1826. if (v.length === 4) { //for shorthand like #9F0
  1827. var c1 = v.charAt(1),
  1828. c2 = v.charAt(2),
  1829. c3 = v.charAt(3);
  1830. v = "#" + c1 + c1 + c2 + c2 + c3 + c3;
  1831. }
  1832. v = parseInt(v.substr(1), 16);
  1833. return [v >> 16, (v >> 8) & 255, v & 255];
  1834. } else {
  1835. return v.match(_numExp) || _colorLookup.transparent;
  1836. }
  1837. },
  1838. _getIEOpacity = function(obj) {
  1839. return (_opacityExp.test( ((typeof(obj) === "string") ? obj : (obj.currentStyle ? obj.currentStyle.filter : obj.style.filter) || "") ) ? ( parseFloat( RegExp.$1 ) / 100 ) : 1);
  1840. },
  1841. _getComputedStyle = (_doc.defaultView) ? _doc.defaultView.getComputedStyle : function(o,s) {},
  1842. //gets an individual style property. cs is for computedStyle (a speed optimization - we don't want to run it more than once if we don't have to). calc forces the returned value to be based on the computedStyle, ignoring anything that's in the element's "style" property (computing normalizes certain things for us)
  1843. _getStyle = function(t, p, cs, calc) {
  1844. if (!_supportsOpacity && p === "opacity") { //several versions of IE don't use the standard "opacity" property - they use things like filter:alpha(opacity=50), so we parse that here.
  1845. return _getIEOpacity(t);
  1846. } else if (!calc && t.style[p]) {
  1847. return t.style[p];
  1848. } else if ((cs = cs || _getComputedStyle(t, null))) {
  1849. t = cs.getPropertyValue(p.replace(_capsExp, "-$1").toLowerCase());
  1850. return (t || cs.length) ? t : cs[p]; //Opera behaves VERY strangely - length is usually 0 and cs[p] is the only way to get accurate results EXCEPT when checking for -o-transform which only works with cs.getPropertyValue()!
  1851. } else if (t.currentStyle) {
  1852. cs = t.currentStyle,
  1853. calc = cs[p]; //reuse "calc" variable to reduce minification size and improve speed slightly compared to creating a new variable.
  1854. if (!calc && p === "backgroundPosition") { //IE doesn't report backgroundPosition accurately (before version 9) - instead, it only reports backgroundPositionX and backgroundPositionY, so we need to combine them manually.
  1855. return cs[p + "X"] + " " + cs[p + "Y"];
  1856. }
  1857. return calc;
  1858. }
  1859. return null;
  1860. },
  1861. //returns at object containing ALL of the style properties in camel-case and their associated values.
  1862. _getStyles = function(t, cs) {
  1863. var s = {}, i;
  1864. if ((cs = cs || _getComputedStyle(t, null))) {
  1865. if ((i = cs.length)) {
  1866. while (--i > -1) {
  1867. s[cs[i].replace(_camelExp, _camelFunc)] = cs.getPropertyValue(cs[i]);
  1868. }
  1869. } else { //Opera behaves differently - cs.length is always 0, so we must do a for...in loop.
  1870. for (i in cs) {
  1871. s[i] = cs[i];
  1872. }
  1873. }
  1874. } else if ((cs = t.currentStyle || t.style)) {
  1875. for (i in cs) {
  1876. s[i.replace(_camelExp, _camelFunc)] = cs[i];
  1877. }
  1878. }
  1879. if (!_supportsOpacity) {
  1880. s.opacity = _getIEOpacity(t);
  1881. }
  1882. var tr = _getTransform(t, cs, false);
  1883. s.rotation = tr.rotation * _RAD2DEG;
  1884. s.skewX = tr.skewX * _RAD2DEG;
  1885. s.scaleX = tr.scaleX;
  1886. s.scaleY = tr.scaleY;
  1887. s.x = tr.x;
  1888. s.y = tr.y;
  1889. if (s.filters != null) {
  1890. delete s.filters;
  1891. }
  1892. return s;
  1893. },
  1894. //analyzes two style objects (as returned by _getStyles()) and only looks for differences between them that contain tweenable values (like a number or color). It returns an object containing only those isolated properties and values for tweening, and optionally populates an array of those property names too (so that we can loop through them at the end of the tween and remove them for css tweens that apply a className - we don't want the cascading to get messed up)
  1895. _cssDif = function(s1, s2, v, d) {
  1896. var s = {}, val, p;
  1897. for (p in s2) {
  1898. if (p !== "cssText") if (p !== "length") if (isNaN(p)) if (s1[p] != (val = s2[p])) if (val !== _transformProp) if (typeof(val) === "number" || typeof(val) === "string") {
  1899. s[p] = ((val === "" || val === "auto") && typeof(s1[p]) === "string" && s1[p].replace(_NaNExp, "") !== "") ? 0 : val; //if the ending value is defaulting ("" or "auto"), we check the starting value and if it can be parsed into a number (a string which could have a suffix too, like 700px), then we swap in 0 for "" or "auto" so that things actually tween.
  1900. if (d) {
  1901. d.props.push(p);
  1902. }
  1903. }
  1904. }
  1905. if (v) {
  1906. for (p in v) { //copy properties (except className)
  1907. if (p !== "className") {
  1908. s[p] = v[p];
  1909. }
  1910. }
  1911. }
  1912. return s;
  1913. },
  1914. _transformMap = {scaleX:1, scaleY:1, x:1, y:1, rotation:1, shortRotation:1, skewX:1, skewY:1, scale:1},
  1915. _prefixCSS = "", //the non-camelCase vendor prefix like "-o-", "-moz-", "-ms-", or "-webkit-"
  1916. _prefix = "", //camelCase vendor prefix like "O", "ms", "Webkit", or "Moz".
  1917. //feed in a camelCase property name like "transform" and it will check to see if it is valid as-is or if it needs a vendor prefix. It returns the corrected camelCase property name (i.e. "WebkitTransform" or "MozTransform" or "transform" or null if no such property is found, like if the browser is IE8 or before, "transform" won't be found at all)
  1918. _checkPropPrefix = function(p, e) {
  1919. e = e || _tempDiv;
  1920. var s = e.style,
  1921. a, i;
  1922. if (s[p] !== undefined) {
  1923. return p;
  1924. }
  1925. p = p.substr(0,1).toUpperCase() + p.substr(1);
  1926. a = ["O","Moz","ms","Ms","Webkit"];
  1927. i = 5;
  1928. while (--i > -1 && s[a[i]+p] === undefined) { }
  1929. if (i >= 0) {
  1930. _prefix = (i === 3) ? "ms" : a[i];
  1931. _prefixCSS = "-" + _prefix.toLowerCase() + "-";
  1932. return _prefix + p;
  1933. }
  1934. return null;
  1935. },
  1936. _transformProp = _checkPropPrefix("transform"), //the Javascript (camelCase) transform property, like msTransform, WebkitTransform, MozTransform, or OTransform.
  1937. _transformPropCSS = _prefixCSS + "transform",
  1938. //parses the transform values for an element, returning an object with x, y, scaleX, scaleY, rotation, skewX, and skewY properties. Note: by default (for performance reasons), all skewing is combined into skewX and rotation but skewY still has a place in the transform object so that we can record how much of the skew is attributed to skewX vs skewY. Remember, a skewY of 10 looks the same as a rotation of 10 and skewX of -10.
  1939. _getTransform = function(t, cs, rec) {
  1940. var tm = t._gsTransform, s;
  1941. if (_transformProp) {
  1942. s = _getStyle(t, _transformPropCSS, cs, true);
  1943. } else if (t.currentStyle) {
  1944. //for older versions of IE, we need to interpret the filter portion that is in the format: progid:DXImageTransform.Microsoft.Matrix(M11=6.123233995736766e-17, M12=-1, M21=1, M22=6.123233995736766e-17, sizingMethod='auto expand') Notice that we need to swap b and c compared to a normal matrix.
  1945. s = t.currentStyle.filter.match(_ieGetMatrixExp);
  1946. s = (s && s.length === 4) ? s[0].substr(4) + "," + Number(s[2].substr(4)) + "," + Number(s[1].substr(4)) + "," + s[3].substr(4) + "," + (tm ? tm.x : 0) + "," + (tm ? tm.y : 0) : null;
  1947. }
  1948. var v = (s || "").replace(/[^\d\-\.e,]/g, "").split(","),
  1949. k = (v.length >= 6),
  1950. a = k ? Number(v[0]) : 1,
  1951. b = k ? Number(v[1]) : 0,
  1952. c = k ? Number(v[2]) : 0,
  1953. d = k ? Number(v[3]) : 1,
  1954. min = 0.000001,
  1955. m = rec ? tm || {skewY:0} : {skewY:0},
  1956. invX = (m.scaleX < 0); //in order to interpret things properly, we need to know if the user applied a negative scaleX previously so that we can adjust the rotation and skewX accordingly. Otherwise, if we always interpret a flipped matrix as affecting scaleY and the user only wants to tween the scaleX on multiple sequential tweens, it would keep the negative scaleY without that being the user's intent.
  1957. m.x = (k ? Number(v[4]) : 0);
  1958. m.y = (k ? Number(v[5]) : 0);
  1959. m.scaleX = Math.sqrt(a * a + b * b);
  1960. m.scaleY = Math.sqrt(d * d + c * c);
  1961. m.rotation = (a || b) ? Math.atan2(b, a) : m.rotation || 0; //note: if scaleX is 0, we cannot accurately measure rotation. Same for skewX with a scaleY of 0. Therefore, we default to the previously recorded value (or zero if that doesn't exist).
  1962. m.skewX = (c || d) ? Math.atan2(c, d) + m.rotation : m.skewX || 0;
  1963. if (Math.abs(m.skewX) > Math.PI / 2) {
  1964. if (invX) {
  1965. m.scaleX *= -1;
  1966. m.skewX += (m.rotation <= 0) ? Math.PI : -Math.PI;
  1967. m.rotation += (m.rotation <= 0) ? Math.PI : -Math.PI;
  1968. } else {
  1969. m.scaleY *= -1;
  1970. m.skewX += (m.skewX <= 0) ? Math.PI : -Math.PI;
  1971. }
  1972. }
  1973. //some browsers have a hard time with very small values like 2.4492935982947064e-16 (notice the "e-" towards the end) and would render the object slightly off. So we round to 0 in these cases. The conditional logic here is faster than calling Math.abs().
  1974. if (m.rotation < min) if (m.rotation > -min) if (a || b) {
  1975. m.rotation = 0;
  1976. }
  1977. if (m.skewX < min) if (m.skewX > -min) if (b || c) {
  1978. m.skewX = 0;
  1979. }
  1980. if (rec) {
  1981. t._gsTransform = m; //record to the object's _gsTransform which we use so that tweens can control individual properties independently (we need all the properties to accurately recompose the matrix in the setRatio() method)
  1982. }
  1983. return m;
  1984. },
  1985. _dimensions = {width:["Left","Right"], height:["Top","Bottom"]},
  1986. _margins = ["marginLeft","marginRight","marginTop","marginBottom"],
  1987. _getDimension = function(n, t, cs) {
  1988. var v = parseFloat((n === "width") ? t.offsetWidth : t.offsetHeight),
  1989. a = _dimensions[n],
  1990. i = a.length,
  1991. cs = cs || _getComputedStyle(t, null);
  1992. while (--i > -1) {
  1993. v -= parseFloat( _getStyle(t, "padding" + a[i], cs, true) ) || 0;
  1994. v -= parseFloat( _getStyle(t, "border" + a[i] + "Width", cs, true) ) || 0;
  1995. }
  1996. return v;
  1997. },
  1998. //pass the target element, the property name, the numeric value, and the suffix (like "%", "em", "px", etc.) and it will spit back the equivalent pixel number
  1999. _convertToPixels = function(t, p, v, sfx, recurse) {
  2000. if (sfx === "px" || !sfx) { return v; }
  2001. if (sfx === "auto" || !v) { return 0; }
  2002. var horiz = _horizExp.test(p),
  2003. node = t,
  2004. style = _tempDiv.style,
  2005. neg = (v < 0);
  2006. if (neg) {
  2007. v = -v;
  2008. }
  2009. style.cssText = "border-style:solid; border-width:0; position:absolute; line-height:0;";
  2010. if (sfx === "%" || sfx === "em" || !node.appendChild) {
  2011. node = t.parentNode || _doc.body;
  2012. style[(horiz ? "width" : "height")] = v + sfx;
  2013. } else {
  2014. style[(horiz ? "borderLeftWidth" : "borderTopWidth")] = v + sfx;
  2015. }
  2016. node.appendChild(_tempDiv);
  2017. var pix = parseFloat(_tempDiv[(horiz ? "offsetWidth" : "offsetHeight")]);
  2018. node.removeChild(_tempDiv);
  2019. if (pix === 0 && !recurse) { //in some browsers (like IE7/8), occasionally the value isn't accurately reported initially, but if we run the function again it will take effect.
  2020. pix = _convertToPixels(t, p, v, sfx, true);
  2021. }
  2022. return neg ? -pix : pix;
  2023. },
  2024. //for parsing things like transformOrigin or backgroundPosition which must recognize keywords like top/left/right/bottom/center as well as percentages and pixel values. Decorates the supplied object with the following properties: "ox" (offsetX), "oy" (offsetY), "oxp" (if true, "ox" is a percentage not a pixel value), and "oxy" (if true, "oy" is a percentage not a pixel value)
  2025. _parsePosition = function(v, o) {
  2026. if (v == null || v === "" || v === "auto" || v === "auto auto") { //note: Firefox uses "auto auto" as default whereas Chrome uses "auto".
  2027. v = "0 0";
  2028. }
  2029. o = o || {};
  2030. var x = (v.indexOf("left") !== -1) ? "0%" : (v.indexOf("right") !== -1) ? "100%" : v.split(" ")[0],
  2031. y = (v.indexOf("top") !== -1) ? "0%" : (v.indexOf("bottom") !== -1) ? "100%" : v.split(" ")[1];
  2032. if (y == null) {
  2033. y = "0";
  2034. } else if (y === "center") {
  2035. y = "50%";
  2036. }
  2037. if (x === "center") {
  2038. x = "50%";
  2039. }
  2040. o.oxp = (x.indexOf("%") !== -1);
  2041. o.oyp = (y.indexOf("%") !== -1);
  2042. o.oxr = (x.charAt(1) === "=");
  2043. o.oyr = (y.charAt(1) === "=");
  2044. o.ox = parseFloat(x.replace(_NaNExp, ""));
  2045. o.oy = parseFloat(y.replace(_NaNExp, ""));
  2046. return o;
  2047. },
  2048. //takes a value and a default number, checks if the value is relative, null, or numeric and spits back a normalized number accordingly. Primarily used in the _parseTransform() function.
  2049. _parseVal = function(v, d) {
  2050. return (v == null) ? d : (typeof(v) === "string" && v.indexOf("=") === 1) ? Number(v.split("=").join("")) + d : Number(v);
  2051. },
  2052. //translates strings like "40deg" or "40" or 40rad" or "+=40deg" to a numeric radian angle, optionally relative to a default value (if "+=" or "-=" prefix is found)
  2053. _parseAngle = function(v, d) {
  2054. var m = (v.indexOf("rad") === -1) ? _DEG2RAD : 1,
  2055. r = (v.indexOf("=") === 1);
  2056. v = Number(v.replace(_NaNExp, "")) * m;
  2057. return r ? v + d : v;
  2058. },
  2059. _colorLookup = {aqua:[0,255,255],
  2060. lime:[0,255,0],
  2061. silver:[192,192,192],
  2062. black:[0,0,0],
  2063. maroon:[128,0,0],
  2064. teal:[0,128,128],
  2065. blue:[0,0,255],
  2066. navy:[0,0,128],
  2067. white:[255,255,255],
  2068. fuchsia:[255,0,255],
  2069. olive:[128,128,0],
  2070. yellow:[255,255,0],
  2071. orange:[255,165,0],
  2072. gray:[128,128,128],
  2073. purple:[128,0,128],
  2074. green:[0,128,0],
  2075. red:[255,0,0],
  2076. pink:[255,192,203],
  2077. cyan:[0,255,255],
  2078. transparent:[255,255,255,0]};
  2079. //gets called when the tween renders for the first time. This kicks everything off, recording start/end values, etc.
  2080. p._onInitTween = function(target, value, tween) {
  2081. if (!target.nodeType) { //css is only for dom elements
  2082. return false;
  2083. }
  2084. this._target = target;
  2085. this._tween = tween;
  2086. this._classData = this._transform = null; //_transform is only used for scaleX/scaleY/x/y/rotation/skewX/skewY tweens and _classData is only used if className is defined - this will be an array of properties that we're tweening related to the class which should be removed from the target.style at the END of the tween when the className is populated so that cascading happens properly.
  2087. _autoRound = value.autoRound;
  2088. var s = this._style = target.style,
  2089. cs = _getComputedStyle(target, ""),
  2090. copy, start, v;
  2091. if (_reqSafariFix) if (s.zIndex === "") {
  2092. v = _getStyle(target, "zIndex", cs);
  2093. if (v === "auto" || v === "") {
  2094. //corrects a bug in [non-Android] Safari that prevents it from repainting elements in their new positions if they don't have a zIndex set. We also can't just apply this inside _parseTransform() because anything that's moved in any way (like using "left" or "top" instead of transforms like "x" and "y") can be affected, so it is best to ensure that anything that's tweening has a z-index. Setting "WebkitPerspective" to a non-zero value worked too except that on iOS Safari things would flicker randomly. Plus zIndex is less memory-intensive.
  2095. s.zIndex = 0;
  2096. }
  2097. }
  2098. if (typeof(value) === "string") {
  2099. copy = s.cssText;
  2100. start = _getStyles(target, cs);
  2101. s.cssText = copy + ";" + value;
  2102. v = _cssDif(start, _getStyles(target));
  2103. if (!_supportsOpacity && _opacityValExp.test(value)) {
  2104. v.opacity = parseFloat( RegExp.$1 );
  2105. }
  2106. value = v;
  2107. s.cssText = copy;
  2108. } else if (value.className) {
  2109. copy = target.className;
  2110. this._classData = {b:copy, e:(value.className.charAt(1) !== "=") ? value.className : (value.className.charAt(0) === "+") ? target.className + " " + value.className.substr(2) : target.className.split(value.className.substr(2)).join(""), props:[]}
  2111. if (tween._duration) { //if it's a zero-duration tween, there's no need to tween anything or parse the data. In fact, if we switch classes temporarily (which we must do for proper parsing) and the class has a transition applied, it could cause a quick flash to the end state and back again initially in some browsers.
  2112. start = _getStyles(target, cs);
  2113. target.className = this._classData.e;
  2114. value = _cssDif(start, _getStyles(target), value, this._classData);
  2115. target.className = copy;
  2116. } else {
  2117. value = {};
  2118. }
  2119. }
  2120. this._parseVars(value, target, cs, value.suffixMap || CSSPlugin.suffixMap);
  2121. return true;
  2122. }
  2123. //feed a vars object to this function and it will parse through its properties and add PropTweens as necessary. This is split out from the _onInitTween() so that we can recurse if necessary, like "margin" should affect "marginLeft", "marginRight", "marginTop", and "marginBottom".
  2124. p._parseVars = function(vars, t, cs, map) {
  2125. var s = this._style,
  2126. p, v, pt, beg, clr1, clr2, bsfx, esfx, rel, start, copy, isStr;
  2127. for (p in vars) {
  2128. v = vars[p];
  2129. if (p === "transform" || p === _transformProp) {
  2130. this._parseTransform(t, v, cs, map);
  2131. continue;
  2132. } else if (_transformMap[p] || p === "transformOrigin") {
  2133. this._parseTransform(t, vars, cs, map);
  2134. continue;
  2135. } else if (p === "alpha" || p === "autoAlpha") { //alpha tweens are opacity tweens
  2136. p = "opacity";
  2137. } else if (p === "margin" || p === "padding") {
  2138. copy = (v + "").split(" ");
  2139. rel = copy.length;
  2140. pt = {};
  2141. pt[p + "Top"] = copy[0];
  2142. pt[p + "Right"] = (rel > 1) ? copy[1] : copy[0];
  2143. pt[p + "Bottom"] = (rel === 4) ? copy[2] : copy[0];
  2144. pt[p + "Left"] = (rel === 4) ? copy[3] : (rel === 2) ? copy[1] : copy[0];
  2145. this._parseVars(pt, t, cs, map);
  2146. continue;
  2147. } else if (p === "backgroundPosition" || p === "backgroundSize") {
  2148. pt = _parsePosition(v); //end values
  2149. start = _parsePosition( (beg = _getStyle(t, p, cs)) ); //starting values
  2150. this._firstPT = pt = {_next:this._firstPT, t:s, p:p, b:beg, f:false, n:"css_" + p, type:3,
  2151. s:start.ox, //x start
  2152. c:pt.oxr ? pt.ox : pt.ox - start.ox, //change in x
  2153. ys:start.oy, //y start
  2154. yc:pt.oyr ? pt.oy : pt.oy - start.oy, //change in y
  2155. sfx:pt.oxp ? "%" : "px", //x suffix
  2156. ysfx:pt.oyp ? "%" : "px", //y suffix
  2157. r:(!pt.oxp && vars.autoRound !== false)};
  2158. pt.e = (pt.s + pt.c) + pt.sfx + " " + (pt.ys + pt.yc) + pt.ysfx; //we can't just use v because it could contain relative values, like +=50px which is an illegal final value.
  2159. continue;
  2160. } else if (p === "border") {
  2161. copy = (v + "").split(" ");
  2162. this._parseVars({borderWidth:copy[0], borderStyle:copy[1] || "none", borderColor:copy[2] || "#000000"}, t, cs, map);
  2163. continue;
  2164. } else if (p === "bezier") {
  2165. this._parseBezier(v, t, cs, map);
  2166. continue;
  2167. } else if (p === "autoRound") {
  2168. continue;
  2169. }
  2170. beg = _getStyle(t, p, cs);
  2171. beg = (beg != null) ? beg + "" : ""; //make sure beginning value is a string. Don't do beg = _getStyle(...) || "" because if _getStyle() returns 0, it will make it "" since 0 is a "falsey" value.
  2172. //Some of these properties are in place in order to conform with the standard PropTweens in TweenPlugins so that overwriting and roundProps occur properly. For example, f and r may seem unnecessary here, but they enable other functionality.
  2173. //_next:* next linked list node [object]
  2174. //t: * target [object]
  2175. //p: * property (camelCase) [string]
  2176. //s: * starting value [number]
  2177. //c: * change value [number]
  2178. //f: * is function [boolean]
  2179. //n: * name (for overwriting) [string]
  2180. //sfx: suffix [string]
  2181. //b: beginning value [string]
  2182. //i: intermediate value [string]
  2183. //e: ending value [string]
  2184. //r: * round [boolean]
  2185. //type: 0=normal, 1=color, 2=rgba, 3=positional offset (like backgroundPosition or backgroundSize), 4=unsupported opacity (ie), -1=non-tweening prop [number]
  2186. this._firstPT = pt = {_next:this._firstPT,
  2187. t:s,
  2188. p:p,
  2189. b:beg,
  2190. f:false,
  2191. n:"css_" + p,
  2192. sfx:"",
  2193. r:false,
  2194. type:0};
  2195. //if it's an autoAlpha, add a new PropTween for "visibility". We must make sure the "visibility" PropTween comes BEFORE the "opacity" one in order to work around a bug in old versions of IE tht would ignore "visibility" changes if made right after an alpha change. Remember, we add PropTweens in reverse order - that's why we do this here, after creating the original PropTween.
  2196. if (p === "opacity") if (vars.autoAlpha != null) {
  2197. if (beg === "1") if (_getStyle(t, "visibility", cs) === "hidden") { //if visibility is initially set to "hidden", we should interpret that as intent to make opacity 0.
  2198. beg = pt.b = "0";
  2199. }
  2200. this._firstPT = pt._prev = {_next:pt, t:s, p:"visibility", f:false, n:"css_visibility", r:false, type:-1, b:(Number(beg) !== 0) ? "visible" : "hidden", i:"visible", e:(Number(v) === 0) ? "hidden" : "visible"};
  2201. this._overwriteProps.push("css_visibility");
  2202. }
  2203. isStr = (typeof(v) === "string");
  2204. //color values must be split apart into their R, G, B (and sometimes alpha) values and tweened independently.
  2205. if (p === "color" || p === "fill" || p === "stroke" || p.indexOf("Color") !== -1 || (isStr && !v.indexOf("rgb("))) { //Opera uses background: to define color sometimes in addition to backgroundColor:
  2206. clr1 = _parseColor(beg);
  2207. clr2 = _parseColor(v);
  2208. pt.e = pt.i = ((clr2.length > 3) ? "rgba(" : "rgb(") + clr2.join(",") + ")"; //don't just do pt.e = v because that won't work if the destination color is numeric, like 0xFF0000. We need to parse it.
  2209. pt.b = ((clr1.length > 3) ? "rgba(" : "rgb(") + clr1.join(",") + ")"; //normalize to rgb in case the beginning value was passed in as numeric, like 0xFF0000
  2210. pt.s = Number(clr1[0]); //red starting value
  2211. pt.c = Number(clr2[0]) - pt.s; //red change
  2212. pt.gs = Number(clr1[1]); //green starting value
  2213. pt.gc = Number(clr2[1]) - pt.gs; //green change
  2214. pt.bs = Number(clr1[2]); //blue starting value
  2215. pt.bc = Number(clr2[2]) - pt.bs; //blue change
  2216. pt.type = 1;
  2217. if (clr1.length > 3 || clr2.length > 3) { //detect an rgba() value
  2218. if (_supportsOpacity) {
  2219. pt.as = (clr1.length < 4) ? 1 : Number(clr1[3]);
  2220. pt.ac = ((clr2.length < 4) ? 1 : Number(clr2[3])) - pt.as;
  2221. pt.type = 2;
  2222. } else { //older versions of IE don't support rgba(), so if the destination alpha is 0, just use "transparent" for the color and make it a non-tweening property
  2223. if (clr2[3] == 0) {
  2224. pt.e = pt.i = "transparent";
  2225. pt.type = -1;
  2226. }
  2227. if (clr1[3] == 0) {
  2228. pt.b = "transparent";
  2229. }
  2230. }
  2231. }
  2232. } else {
  2233. bsfx = beg.replace(_suffixExp, ""); //beginning suffix
  2234. if (beg === "" || beg === "auto") {
  2235. if (p === "width" || p === "height") {
  2236. start = _getDimension(p, t, cs);
  2237. bsfx = "px";
  2238. } else {
  2239. start = (p !== "opacity") ? 0 : 1;
  2240. bsfx = "";
  2241. }
  2242. } else {
  2243. start = (beg.indexOf(" ") === -1) ? parseFloat(beg.replace(_NaNExp, "")) : NaN;
  2244. }
  2245. if (isStr) {
  2246. rel = (v.charAt(1) === "=");
  2247. esfx = v.replace(_suffixExp, "");
  2248. v = (v.indexOf(" ") === -1) ? parseFloat(v.replace(_NaNExp, "")) : NaN;
  2249. } else {
  2250. rel = false;
  2251. esfx = "";
  2252. }
  2253. if (esfx === "") {
  2254. esfx = map[p] || bsfx; //populate the end suffix, prioritizing the map, then if none is found, use the beginning suffix.
  2255. }
  2256. pt.e = (v || v === 0) ? (rel ? v + start : v) + esfx : vars[p]; //ensures that any += or -= prefixes are taken care of. Record the end value before normalizing the suffix because we always want to end the tween on exactly what they intended even if it doesn't match the beginning value's suffix.
  2257. //if the beginning/ending suffixes don't match, normalize them...
  2258. if (bsfx !== esfx) if (esfx !== "") if (v || v === 0) if (start || start === 0) {
  2259. start = _convertToPixels(t, p, start, bsfx);
  2260. if (esfx === "%") {
  2261. start /= _convertToPixels(t, p, 100, "%") / 100;
  2262. if (start > 100) { //extremely rare
  2263. start = 100;
  2264. }
  2265. } else if (esfx === "em") {
  2266. start /= _convertToPixels(t, p, 1, "em");
  2267. //otherwise convert to pixels.
  2268. } else {
  2269. v = _convertToPixels(t, p, v, esfx);
  2270. esfx = "px"; //we don't use bsfx after this, so we don't need to set it to px too.
  2271. }
  2272. if (rel) if (v || v === 0) {
  2273. pt.e = (v + start) + esfx; //the changes we made affect relative calculations, so adjust the end value here.
  2274. }
  2275. }
  2276. if ((start || start === 0) && (v || v === 0) && (pt.c = (rel ? v : v - start))) { //faster than isNaN(). Also, we set pt.c (change) here because if it's 0, we'll just treat it like a non-tweening value. can't do (v !== start) because if it's a relative value and the CHANGE is identical to the START, the condition will fail unnecessarily.
  2277. pt.s = start;
  2278. pt.sfx = esfx;
  2279. if (p === "opacity") {
  2280. if (!_supportsOpacity) {
  2281. pt.type = 4;
  2282. pt.p = "filter";
  2283. pt.b = "alpha(opacity=" + (pt.s * 100) + ")";
  2284. pt.e = "alpha(opacity=" + ((pt.s + pt.c) * 100) + ")";
  2285. pt.dup = (vars.autoAlpha != null); //dup = duplicate the setting of the alpha in order to work around a bug in IE7 and IE8 that prevents changes to "visibility" from taking effect if the filter is changed to a different alpha(opacity) at the same time. Setting it to the SAME value first, then the new value works around the IE7/8 bug.
  2286. this._style.zoom = 1; //helps correct an IE issue.
  2287. }
  2288. } else if (_autoRound !== false && (esfx === "px" || p === "zIndex")) { //always round zIndex, and as long as autoRound isn't false, round pixel values (that improves performance in browsers typically)
  2289. pt.r = true;
  2290. }
  2291. } else {
  2292. pt.type = -1;
  2293. pt.i = (p === "display" && pt.e === "none") ? pt.b : pt.e; //intermediate value is typically the same as the end value except for "display"
  2294. pt.s = pt.c = 0;
  2295. }
  2296. }
  2297. this._overwriteProps.push("css_" + p);
  2298. if (pt._next) {
  2299. pt._next._prev = pt;
  2300. }
  2301. }
  2302. }
  2303. //compares the beginning x, y, scaleX, scaleY, rotation, and skewX properties with the ending ones and adds PropTweens accordingly wherever necessary. We must tween them individually (rather than just tweening the matrix values) so that elgant overwriting can occur, like if one tween is controlling scaleX, scaleY, and rotation and then another one starts mid-tween that is trying to control the scaleX only - this tween should continue tweening scaleY and rotation.
  2304. p._parseTransform = function(t, v, cs, map) {
  2305. if (this._transform) { return; } //only need to parse the transform once, and only if the browser supports it.
  2306. var m1 = this._transform = _getTransform(t, cs, true),
  2307. s = this._style,
  2308. min = 0.000001,
  2309. m2, skewY, p, pt, copy, orig;
  2310. if (typeof(v) === "object") { //for values like scaleX, scaleY, rotation, x, y, skewX, and skewY or transform:{...} (object)
  2311. m2 = {scaleX:_parseVal((v.scaleX != null) ? v.scaleX : v.scale, m1.scaleX),
  2312. scaleY:_parseVal((v.scaleY != null) ? v.scaleY : v.scale, m1.scaleY),
  2313. x:_parseVal(v.x, m1.x),
  2314. y:_parseVal(v.y, m1.y)};
  2315. if (v.shortRotation != null) {
  2316. m2.rotation = (typeof(v.shortRotation) === "number") ? v.shortRotation * _DEG2RAD : _parseAngle(v.shortRotation, m1.rotation);
  2317. var dif = (m2.rotation - m1.rotation) % (Math.PI * 2);
  2318. if (dif !== dif % Math.PI) {
  2319. dif += Math.PI * ((dif < 0) ? 2 : -2);
  2320. }
  2321. m2.rotation = m1.rotation + dif;
  2322. } else {
  2323. m2.rotation = (v.rotation == null) ? m1.rotation : (typeof(v.rotation) === "number") ? v.rotation * _DEG2RAD : _parseAngle(v.rotation, m1.rotation);
  2324. }
  2325. m2.skewX = (v.skewX == null) ? m1.skewX : (typeof(v.skewX) === "number") ? v.skewX * _DEG2RAD : _parseAngle(v.skewX, m1.skewX);
  2326. //note: for performance reasons, we combine all skewing into the skewX and rotation values, ignoring skewY but we must still record it so that we can discern how much of the overall skew is attributed to skewX vs. skewY. Otherwise, if the skewY would always act relative (tween skewY to 10deg, for example, multiple times and if we always combine things into skewX, we can't remember that skewY was 10 from last time). Remember, a skewY of 10 degrees looks the same as a rotation of 10 degrees plus a skewX of -10 degrees.
  2327. m2.skewY = (v.skewY == null) ? m1.skewY : (typeof(v.skewY) === "number") ? v.skewY * _DEG2RAD : _parseAngle(v.skewY, m1.skewY);
  2328. if ((skewY = m2.skewY - m1.skewY)) {
  2329. m2.skewX += skewY
  2330. m2.rotation += skewY;
  2331. }
  2332. //don't allow rotation/skew values to be a SUPER small decimal because when they're translated back to strings for setting the css property, the browser reports them in a funky way, like 1-e7. Of course we could use toFixed() to resolve that issue but that hurts performance quite a bit with all those function calls on every frame, plus it is virtually impossible to discern values that small visually (nobody will notice changing a rotation of 0.0000001 to 0, so the performance improvement is well worth it).
  2333. if (m2.skewY < min) if (m2.skewY > -min) {
  2334. m2.skewY = 0;
  2335. }
  2336. if (m2.skewX < min) if (m2.skewX > -min) {
  2337. m2.skewX = 0;
  2338. }
  2339. if (m2.rotation < min) if (m2.rotation > -min) {
  2340. m2.rotation = 0;
  2341. }
  2342. //if a transformOrigin is defined, handle it here...
  2343. if ((orig = v.transformOrigin) != null) {
  2344. if (_transformProp) {
  2345. p = _transformProp + "Origin";
  2346. this._firstPT = pt = {_next:this._firstPT, t:s, p:p, s:0, c:0, n:p, f:false, r:false, b:s[p], e:orig, i:orig, type:-1, sfx:""};
  2347. if (pt._next) {
  2348. pt._next._prev = pt;
  2349. }
  2350. //for older versions of IE (6-8), we need to manually calculate things inside the setRatio() function. We record origin x and y (ox and oy) and whether or not the values are percentages (oxp and oyp).
  2351. } else {
  2352. _parsePosition(orig, m1);
  2353. }
  2354. }
  2355. } else if (typeof(v) === "string" && _transformProp) { //for values like transform:"rotate(60deg) scale(0.5, 0.8)"
  2356. copy = s[_transformProp];
  2357. s[_transformProp] = v;
  2358. m2 = _getTransform(t, null, false);
  2359. s[_transformProp] = copy;
  2360. } else {
  2361. return;
  2362. }
  2363. if (!_transformProp) {
  2364. s.zoom = 1; //helps correct an IE issue.
  2365. } else if (_isSafari) {
  2366. _reqSafariFix = true;
  2367. //corrects a bug in [non-Android] Safari that causes it to skip rendering changes to "top" and "left" that are made on the same frame/render as a transform update. It also helps work around bugs in iOS Safari that can prevent it from repainting elements in their new positions. We cannot just check for a Webkit browser because some Android devices like the Atrix don't like this "fix". Setting "WebkitPerspective" to a non-zero value worked too except that on iOS Safari things would flicker randomly.
  2368. if (s.WebkitBackfaceVisibility === "") {
  2369. s.WebkitBackfaceVisibility = "hidden";
  2370. }
  2371. //if zIndex isn't set, iOS Safari doesn't repaint things correctly sometimes (seemingly at random).
  2372. if (s.zIndex === "") {
  2373. copy = _getStyle(t, "zIndex", cs);
  2374. if (copy === "auto" || copy === "") {
  2375. s.zIndex = 0;
  2376. }
  2377. }
  2378. }
  2379. for (p in _transformMap) {
  2380. if (m1[p] !== m2[p] || _forcePT[p] != null) if (p !== "shortRotation") if (p !== "scale") {
  2381. this._firstPT = pt = {_next:this._firstPT, t:m1, p:p, s:m1[p], c:m2[p] - m1[p], n:p, f:false, r:false, b:m1[p], e:m2[p], type:0, sfx:0};
  2382. if (pt._next) {
  2383. pt._next._prev = pt;
  2384. }
  2385. this._overwriteProps.push("css_" + p);
  2386. }
  2387. }
  2388. };
  2389. p._parseBezier = function(v, t, cs, map) {
  2390. if (!window.com.greensock.plugins.BezierPlugin) {
  2391. console.log("Error: BezierPlugin not loaded.");
  2392. return;
  2393. }
  2394. if (v instanceof Array) {
  2395. v = {values:v};
  2396. }
  2397. var values = v.values || [],
  2398. l = values.length,
  2399. points = [],
  2400. b = this._bezier = {_pt:[]},
  2401. bp = b._proxy = {},
  2402. cnt = 0,
  2403. pcnt = 0,
  2404. lookup = {},
  2405. l2 = l - 1,
  2406. oldForce = _forcePT,
  2407. plugin = b._plugin = new window.com.greensock.plugins.BezierPlugin(),
  2408. p, i, pt, bpt, curPoint, tfm;
  2409. for (i = 0; i < l; i++) {
  2410. curPoint = {};
  2411. this._transform = null; //null each time through, otherwise _parseTransform() will abort
  2412. bpt = this._firstPT;
  2413. this._parseVars((_forcePT = values[i]), t, cs, map);
  2414. pt = this._firstPT;
  2415. if (i === 0) {
  2416. tfm = this._transform;
  2417. while (pt !== bpt) {
  2418. bp[pt.p] = pt.s;
  2419. b._pt[pcnt++] = lookup[pt.p] = pt; //don't rely on the linked list because it's possible that one would get removed (like overwritten), and if that was the one that was attached (like via _lastPT property), it would leave them all stranded, so the array would be more reliable here.
  2420. if (pt.type === 1 || pt.type === 2) {
  2421. bp[pt.p+"_g"] = pt.gs;
  2422. bp[pt.p+"_b"] = pt.bs;
  2423. if (pt.type === 2) {
  2424. bp[pt.p+"_a"] = pt.as;
  2425. }
  2426. } else if (pt.type === 3) {
  2427. bp[pt.p+"_y"] = pt.ys;
  2428. }
  2429. pt = pt._next;
  2430. }
  2431. pt = this._firstPT;
  2432. } else {
  2433. this._firstPT = bpt;
  2434. if (bpt._prev) {
  2435. bpt._prev._next = null;
  2436. }
  2437. bpt._prev = null;
  2438. bpt = null;
  2439. }
  2440. while (pt !== bpt) {
  2441. if (lookup[pt.p]) {
  2442. curPoint[pt.p] = pt.s + pt.c;
  2443. if (i === l2) {
  2444. lookup[pt.p].e = pt.e; //record the end value
  2445. }
  2446. if (pt.type === 1 || pt.type === 2) {
  2447. curPoint[pt.p+"_g"] = pt.gs + pt.gc;
  2448. curPoint[pt.p+"_b"] = pt.bs + pt.bc;
  2449. if (pt.type === 2) {
  2450. curPoint[pt.p+"_a"] = pt.as + pt.ac;
  2451. }
  2452. } else if (pt.type === 3) {
  2453. curPoint[pt.p+"_y"] = pt.ys + pt.yc;
  2454. }
  2455. if (i === 0) {
  2456. pt.c = pt.ac = pt.gc = pt.bc = pt.yc = 0; //no change - the BezierPlugin instance will handle that, and we'll set the "s" (start) property of the PropTween in the setRatio() method, just copying it from the _bezierProxy object.
  2457. }
  2458. }
  2459. pt = pt._next;
  2460. }
  2461. points[cnt++] = curPoint;
  2462. }
  2463. this._transform = tfm;
  2464. _forcePT = oldForce;
  2465. v.values = points;
  2466. if (v.autoRotate === 0) {
  2467. v.autoRotate = true;
  2468. }
  2469. if (v.autoRotate) if (!(v.autoRotate instanceof Array)) {
  2470. i = (v.autoRotate == true) ? 0 : Number(v.autoRotate) * Math.PI / 180;
  2471. v.autoRotate = (points[0].left != null) ? [["left","top","rotation",i,true]] : (points[0].x != null) ? [["x","y","rotation",i,true]] : false;
  2472. }
  2473. if ((b._autoRotate = v.autoRotate)) if (!tfm) {
  2474. this._transform = _getTransform(t, cs, true);
  2475. }
  2476. plugin._onInitTween(bp, v, this._tween);
  2477. v.values = values;
  2478. };
  2479. //gets called every time the tween updates, passing the new ratio (typically a value between 0 and 1, but not always (for example, if an Elastic.easeOut is used, the value can jump above 1 mid-tween). It will always start and 0 and end at 1.
  2480. p.setRatio = function(v) {
  2481. var pt = this._firstPT,
  2482. bz = this._bezier,
  2483. min = 0.000001, val, i, y;
  2484. if (bz) {
  2485. bz._plugin.setRatio(v);
  2486. var bpt = bz._pt,
  2487. bp = bz._proxy;
  2488. i = bpt.length;
  2489. while (--i > -1) {
  2490. pt = bpt[i];
  2491. pt.s = bp[pt.p];
  2492. if (pt.type === 1 || pt.type === 2) {
  2493. pt.gs = bp[pt.p+"_g"];
  2494. pt.bs = bp[pt.p+"_b"];
  2495. if (pt.type === 2) {
  2496. pt.as = bp[pt.p+"_a"];
  2497. }
  2498. } else if (pt.type === 3) {
  2499. pt.ys = bp[pt.p+"_y"];
  2500. }
  2501. }
  2502. if (bz._autoRotate) {
  2503. this._transform.rotation = bp.rotation;
  2504. }
  2505. }
  2506. //at the end of the tween, we set the values to exactly what we received in order to make sure non-tweening values (like "position" or "float" or whatever) are set and so that if the beginning/ending suffixes (units) didn't match and we normalized to px, the value that the user passed in is used here. We check to see if the tween is at its beginning in case it's a from() tween in which case the ratio will actually go from 1 to 0 over the course of the tween (backwards).
  2507. if (v === 1 && (this._tween._time === this._tween._duration || this._tween._time === 0)) {
  2508. while (pt) {
  2509. pt.t[pt.p] = pt.e;
  2510. if (pt.type === 4) if (pt.s + pt.c === 1) { //for older versions of IE that need to use a filter to apply opacity, we should remove the filter if opacity hits 1 in order to improve performance.
  2511. this._style.removeAttribute("filter");
  2512. if (_getStyle(this._target, "filter")) { //if a class is applied that has an alpha filter, it will take effect (we don't want that), so re-apply our alpha filter in that case. We must first remove it and then check.
  2513. pt.t[pt.p] = pt.e;
  2514. }
  2515. }
  2516. pt = pt._next;
  2517. }
  2518. } else if (v || !(this._tween._time === this._tween._duration || this._tween._time === 0)) {
  2519. while (pt) {
  2520. val = pt.c * v + pt.s;
  2521. if (pt.r) {
  2522. val = (val > 0) ? (val + 0.5) >> 0 : (val - 0.5) >> 0;
  2523. } else if (val < min) if (val > -min) {
  2524. val = 0;
  2525. }
  2526. if (!pt.type) {
  2527. pt.t[pt.p] = val + pt.sfx;
  2528. } else if (pt.type === 1) { //rgb()
  2529. pt.t[pt.p] = "rgb(" + (val >> 0) + ", " + ((pt.gs + (v * pt.gc)) >> 0) + ", " + ((pt.bs + (v * pt.bc)) >> 0) + ")";
  2530. } else if (pt.type === 2) { //rgba()
  2531. pt.t[pt.p] = "rgba(" + (val >> 0) + ", " + ((pt.gs + (v * pt.gc)) >> 0) + ", " + ((pt.bs + (v * pt.bc)) >> 0) + ", " + (pt.as + (v * pt.ac)) + ")";
  2532. } else if (pt.type === -1) { //non-tweening
  2533. pt.t[pt.p] = pt.i;
  2534. } else if (pt.type === 3) { //positional property with an x and y, like backgroundPosition or backgroundSize
  2535. y = pt.ys + v * pt.yc;
  2536. if (pt.r) {
  2537. y = (y > 0) ? (y + 0.5) >> 0 : (y - 0.5) >> 0;
  2538. }
  2539. pt.t[pt.p] = val + pt.sfx + " " + y + pt.ysfx;
  2540. } else {
  2541. if (pt.dup) {
  2542. pt.t.filter = pt.t.filter || "alpha(opacity=100)"; //works around bug in IE7/8 that prevents changes to "visibility" from being applied propertly if the filter is changed to a different alpha on the same frame.
  2543. }
  2544. if (pt.t.filter.indexOf("opacity") === -1) { //only used if browser doesn't support the standard opacity style property (IE 7 and 8)
  2545. pt.t.filter += " alpha(opacity=" + ((val * 100) >> 0) + ")"; //we round the value because otherwise, bugs in IE7/8 can prevent "visibility" changes from being applied properly.
  2546. } else {
  2547. pt.t.filter = pt.t.filter.replace(_opacityExp, "opacity=" + ((val * 100) >> 0)); //we round the value because otherwise, bugs in IE7/8 can prevent "visibility" changes from being applied properly.
  2548. }
  2549. }
  2550. pt = pt._next;
  2551. }
  2552. //if the tween is reversed all the way back to the beginning, we need to restore the original values which may have different units (like % instead of px or em or whatever).
  2553. } else {
  2554. while (pt) {
  2555. pt.t[pt.p] = pt.b;
  2556. if (pt.type === 4) if (pt.s === 1) { //for older versions of IE that need to use a filter to apply opacity, we should remove the filter if opacity hits 1 in order to improve performance.
  2557. this._style.removeAttribute("filter");
  2558. if (_getStyle(this._target, "filter")) { //if a class is applied that has an alpha filter, it will take effect (we don't want that), so re-apply our alpha filter in that case. We must first remove it and then check.
  2559. pt.t[pt.p] = pt.b;
  2560. }
  2561. }
  2562. pt = pt._next;
  2563. }
  2564. }
  2565. //apply transform values like x, y, scaleX, scaleY, rotation, skewX, or skewY. We do these after looping through all the PropTweens because those are where the changes are made to scaleX/scaleY/rotation/skewX/skewY/x/y.
  2566. if (this._transform) {
  2567. pt = this._transform; //to improve speed and reduce size, reuse the pt variable as an alias to the _transform property
  2568. //if there is no rotation or skew, browsers render the transform faster if we just feed it the list of transforms like translate() skewX() scale(), otherwise defining the matrix() values directly is fastest.
  2569. if (_transformProp && !pt.rotation && !pt.skewX) {
  2570. this._style[_transformProp] = ((pt.x || pt.y) ? "translate(" + pt.x + "px," + pt.y + "px) " : "") + ((pt.scaleX !== 1 || pt.scaleY !== 1) ? "scale(" + pt.scaleX + "," + pt.scaleY + ")" : "") || "translate(0px,0px)"; //we need to default to translate(0px,0px) to work around a Chrome bug that rears its ugly head when the transform is set to "".
  2571. } else {
  2572. var ang = _transformProp ? pt.rotation : -pt.rotation,
  2573. skew = _transformProp ? ang - pt.skewX : ang + pt.skewX,
  2574. a = Math.cos(ang) * pt.scaleX,
  2575. b = Math.sin(ang) * pt.scaleX,
  2576. c = Math.sin(skew) * -pt.scaleY,
  2577. d = Math.cos(skew) * pt.scaleY,
  2578. cs;
  2579. //some browsers have a hard time with very small values like 2.4492935982947064e-16 (notice the "e-" towards the end) and would render the object slightly off. So we round to 0 in these cases. The conditional logic here is faster than calling Math.abs().
  2580. if (a < min) if (a > -min) {
  2581. a = 0;
  2582. }
  2583. if (b < min) if (b > -min) {
  2584. b = 0;
  2585. }
  2586. if (c < min) if (c > -min) {
  2587. c = 0;
  2588. }
  2589. if (d < min) if (d > -min) {
  2590. d = 0;
  2591. }
  2592. if (_transformProp) {
  2593. this._style[_transformProp] = "matrix(" + a + "," + b + "," + c + "," + d + "," + pt.x + "," + pt.y + ")";
  2594. //only for older versions of IE (6-8), we use a filter and marginLeft/marginTop to simulate the transform.
  2595. } else if ((cs = this._target.currentStyle)) {
  2596. min = b; //just for swapping the variables an inverting them (reused "min" to avoid creating another variable in memory). IE's filter matrix uses a non-standard matrix configuration (angle goes the opposite way, and b and c are reversed and inverted)
  2597. b = -c;
  2598. c = -min;
  2599. var filters = cs.filter;
  2600. this._style.filter = ""; //remove filters so that we can accurately measure offsetWidth/offsetHeight
  2601. var w = this._target.offsetWidth,
  2602. h = this._target.offsetHeight,
  2603. clip = (cs.position !== "absolute"),
  2604. m = "progid:DXImageTransform.Microsoft.Matrix(M11=" + a + ", M12=" + b + ", M21=" + c + ", M22=" + d,
  2605. ox = pt.x,
  2606. oy = pt.y,
  2607. dx, dy;
  2608. //if transformOrigin is being used, adjust the offset x and y
  2609. if (pt.ox != null) {
  2610. dx = ((pt.oxp) ? w * pt.ox * 0.01 : pt.ox) - w / 2;
  2611. dy = ((pt.oyp) ? h * pt.oy * 0.01 : pt.oy) - h / 2;
  2612. ox = dx - (dx * a + dy * b) + pt.x;
  2613. oy = dy - (dx * c + dy * d) + pt.y;
  2614. }
  2615. if (!clip) {
  2616. var mult = (_ieVers < 8) ? 1 : -1, //in Internet Explorer 7 and before, the box model is broken, causing the browser to treat the width/height of the actual rotated filtered image as the width/height of the box itself, but Microsoft corrected that in IE8. We must use a negative offset in IE8 on the right/bottom
  2617. marg, prop, dif;
  2618. dx = pt.ieOffsetX || 0;
  2619. dy = pt.ieOffsetY || 0;
  2620. pt.ieOffsetX = Math.round((w - ((a < 0 ? -a : a) * w + (b < 0 ? -b : b) * h)) / 2 + ox);
  2621. pt.ieOffsetY = Math.round((h - ((d < 0 ? -d : d) * h + (c < 0 ? -c : c) * w)) / 2 + oy);
  2622. for (i = 0; i < 4; i++) {
  2623. prop = _margins[i];
  2624. marg = cs[prop];
  2625. //we need to get the current margin in case it is being tweened separately (we want to respect that tween's changes)
  2626. val = (marg.indexOf("px") !== -1) ? parseFloat(marg) : _convertToPixels(this._target, prop, parseFloat(marg), marg.replace(_suffixExp, "")) || 0;
  2627. if (val !== pt[prop]) {
  2628. dif = (i < 2) ? -pt.ieOffsetX : -pt.ieOffsetY; //if another tween is controlling a margin, we cannot only apply the difference in the ieOffsets, so we essentially zero-out the dx and dy here in that case. We record the margin(s) later so that we can keep comparing them, making this code very flexible.
  2629. } else {
  2630. dif = (i < 2) ? dx - pt.ieOffsetX : dy - pt.ieOffsetY;
  2631. }
  2632. this._style[prop] = (pt[prop] = Math.round( val - dif * ((i === 0 || i === 2) ? 1 : mult) )) + "px";
  2633. }
  2634. m += ", sizingMethod='auto expand')";
  2635. } else {
  2636. dx = (w / 2),
  2637. dy = (h / 2);
  2638. //translate to ensure that transformations occur around the correct origin (default is center).
  2639. m += ", Dx=" + (dx - (dx * a + dy * b) + ox) + ", Dy=" + (dy - (dx * c + dy * d) + oy) + ")";
  2640. }
  2641. if (filters.indexOf("DXImageTransform.Microsoft.Matrix(") !== -1) {
  2642. this._style.filter = filters.replace(_ieSetMatrixExp, m);
  2643. } else {
  2644. this._style.filter = m + " " + filters; //we must always put the transform/matrix FIRST (before alpha(opacity=xx)) to avoid an IE bug that slices part of the object when rotation is applied with alpha.
  2645. }
  2646. //at the end or beginning of the tween, if the matrix is normal (1, 0, 0, 1) and opacity is 100 (or doesn't exist), remove the filter to improve browser performance.
  2647. if (v === 0 || v === 1) if (a === 1) if (b === 0) if (c === 0) if (d === 1) if (!clip || m.indexOf("Dx=0, Dy=0") !== -1) if (!_opacityExp.test(filters) || parseFloat(RegExp.$1) === 100) {
  2648. this._style.removeAttribute("filter");
  2649. }
  2650. }
  2651. }
  2652. }
  2653. //if we're adding/changing a class, we should do so at the END of the tween, and drop any of the associated properties that are in the target.style object in order to preserve proper cascading.
  2654. if (this._classData) {
  2655. pt = this._classData; //speeds things up slightly and helps minification
  2656. if (v === 1 && (this._tween._time === this._tween._duration || this._tween._time === 0)) {
  2657. var i = pt.props.length;
  2658. while (--i > -1) {
  2659. this._style[pt.props[i]] = "";
  2660. }
  2661. this._target.className = pt.e;
  2662. } else if (this._target.className !== pt.b) {
  2663. this._target.className = pt.b;
  2664. }
  2665. }
  2666. }
  2667. //we need to make sure that if alpha or autoAlpha is killed, opacity is too. And autoAlpha affects the "visibility" property.
  2668. p._kill = function(lookup) {
  2669. var copy = lookup, p;
  2670. if (lookup.autoAlpha || lookup.alpha) {
  2671. copy = {};
  2672. for (p in lookup) { //copy the lookup so that we're not changing the original which may be passed elsewhere.
  2673. copy[p] = lookup[p];
  2674. }
  2675. copy.opacity = 1;
  2676. if (copy.autoAlpha) {
  2677. copy.visibility = 1;
  2678. }
  2679. }
  2680. return TweenPlugin.prototype._kill.call(this, copy);
  2681. }
  2682. TweenPlugin.activate([CSSPlugin]);
  2683. return CSSPlugin;
  2684. }, true);
  2685. /*
  2686. * ----------------------------------------------------------------
  2687. * RoundPropsPlugin
  2688. * ----------------------------------------------------------------
  2689. */
  2690. _gsDefine("plugins.RoundPropsPlugin", ["plugins.TweenPlugin"], function(TweenPlugin) {
  2691. var RoundPropsPlugin = function(props, priority) {
  2692. TweenPlugin.call(this, "roundProps", -1);
  2693. this._overwriteProps.length = 0;
  2694. },
  2695. p = RoundPropsPlugin.prototype = new TweenPlugin("roundProps", -1);
  2696. p.constructor = RoundPropsPlugin;
  2697. RoundPropsPlugin.API = 2;
  2698. p._onInitTween = function(target, value, tween) {
  2699. this._tween = tween;
  2700. return true;
  2701. }
  2702. p._onInitAllProps = function() {
  2703. var tween = this._tween,
  2704. rp = (tween.vars.roundProps instanceof Array) ? tween.vars.roundProps : tween.vars.roundProps.split(","),
  2705. i = rp.length,
  2706. lookup = {},
  2707. rpt = tween._propLookup.roundProps,
  2708. prop, pt, next;
  2709. while (--i > -1) {
  2710. lookup[rp[i]] = 1;
  2711. }
  2712. i = rp.length;
  2713. while (--i > -1) {
  2714. prop = rp[i];
  2715. pt = tween._firstPT;
  2716. while (pt) {
  2717. next = pt._next; //record here, because it may get removed
  2718. if (pt.pg) {
  2719. pt.t._roundProps(lookup, true);
  2720. } else if (pt.n === prop) {
  2721. this._add(pt.t, prop, pt.s, pt.c);
  2722. //remove from linked list
  2723. if (next) {
  2724. next._prev = pt._prev;
  2725. }
  2726. if (pt._prev) {
  2727. pt._prev._next = next;
  2728. } else if (_tween._firstPT === pt) {
  2729. tween._firstPT = next;
  2730. }
  2731. pt._next = pt._prev = null;
  2732. tween._propLookup[prop] = rpt;
  2733. }
  2734. pt = next;
  2735. }
  2736. }
  2737. return false;
  2738. }
  2739. p._add = function(target, p, s, c) {
  2740. this._addTween(target, p, s, s + c, p, true);
  2741. this._overwriteProps.push(p);
  2742. }
  2743. TweenPlugin.activate([RoundPropsPlugin]);
  2744. return RoundPropsPlugin;
  2745. }, true);
  2746. /*
  2747. * ----------------------------------------------------------------
  2748. * EasePack
  2749. * ----------------------------------------------------------------
  2750. */
  2751. _gsDefine("easing.Back", ["easing.Ease"], function(Ease) {
  2752. var gs = window.com.greensock,
  2753. _class = gs._class,
  2754. _create = function(n, f) {
  2755. var c = _class("easing." + n, function(){}, true),
  2756. p = c.prototype = new Ease();
  2757. p.constructor = c;
  2758. p.getRatio = f;
  2759. return c;
  2760. },
  2761. //BACK
  2762. _createBack = function(n, f) {
  2763. var c = _class("easing." + n, function(overshoot) {
  2764. this._p1 = (overshoot || overshoot === 0) ? overshoot : 1.70158;
  2765. this._p2 = this._p1 * 1.525;
  2766. }, true),
  2767. p = c.prototype = new Ease();
  2768. p.constructor = c;
  2769. p.getRatio = f;
  2770. p.config = function(overshoot) {
  2771. return new c(overshoot);
  2772. };
  2773. return c;
  2774. },
  2775. BackOut = _createBack("BackOut", function(p) {
  2776. return ((p = p - 1) * p * ((this._p1 + 1) * p + this._p1) + 1);
  2777. }),
  2778. BackIn = _createBack("BackIn", function(p) {
  2779. return p * p * ((this._p1 + 1) * p - this._p1);
  2780. }),
  2781. BackInOut = _createBack("BackInOut", function(p) {
  2782. return ((p *= 2) < 1) ? 0.5 * p * p * ((this._p2 + 1) * p - this._p2) : 0.5 * ((p -= 2) * p * ((this._p2 + 1) * p + this._p2) + 2);
  2783. }),
  2784. //BOUNCE
  2785. BounceOut = _create("BounceOut", function(p) {
  2786. if (p < 1 / 2.75) {
  2787. return 7.5625 * p * p;
  2788. } else if (p < 2 / 2.75) {
  2789. return 7.5625 * (p -= 1.5 / 2.75) * p + .75;
  2790. } else if (p < 2.5 / 2.75) {
  2791. return 7.5625 * (p -= 2.25 / 2.75) * p + .9375;
  2792. } else {
  2793. return 7.5625 * (p -= 2.625 / 2.75) * p + .984375;
  2794. }
  2795. }),
  2796. BounceIn = _create("BounceIn", function(p) {
  2797. if ((p = 1 - p) < 1 / 2.75) {
  2798. return 1 - (7.5625 * p * p);
  2799. } else if (p < 2 / 2.75) {
  2800. return 1 - (7.5625 * (p -= 1.5 / 2.75) * p + .75);
  2801. } else if (p < 2.5 / 2.75) {
  2802. return 1 - (7.5625 * (p -= 2.25 / 2.75) * p + .9375);
  2803. } else {
  2804. return 1 - (7.5625 * (p -= 2.625 / 2.75) * p + .984375);
  2805. }
  2806. }),
  2807. BounceInOut = _create("BounceInOut", function(p) {
  2808. var invert = (p < 0.5);
  2809. if (invert) {
  2810. p = 1 - (p * 2);
  2811. } else {
  2812. p = (p * 2) - 1;
  2813. }
  2814. if (p < 1 / 2.75) {
  2815. p = 7.5625 * p * p;
  2816. } else if (p < 2 / 2.75) {
  2817. p = 7.5625 * (p -= 1.5 / 2.75) * p + .75;
  2818. } else if (p < 2.5 / 2.75) {
  2819. p = 7.5625 * (p -= 2.25 / 2.75) * p + .9375;
  2820. } else {
  2821. p = 7.5625 * (p -= 2.625 / 2.75) * p + .984375;
  2822. }
  2823. return invert ? (1 - p) * 0.5 : p * 0.5 + 0.5;
  2824. }),
  2825. //CIRC
  2826. CircOut = _create("CircOut", function(p) {
  2827. return Math.sqrt(1 - (p = p - 1) * p);
  2828. }),
  2829. CircIn = _create("CircIn", function(p) {
  2830. return -(Math.sqrt(1 - (p * p)) - 1);
  2831. }),
  2832. CircInOut = _create("CircInOut", function(p) {
  2833. return ((p*=2) < 1) ? -0.5 * (Math.sqrt(1 - p * p) - 1) : 0.5 * (Math.sqrt(1 - (p -= 2) * p) + 1);
  2834. }),
  2835. //ELASTIC
  2836. _2PI = Math.PI * 2,
  2837. _createElastic = function(n, f, def) {
  2838. var c = _class("easing." + n, function(amplitude, period) {
  2839. this._p1 = amplitude || 1;
  2840. this._p2 = period || def;
  2841. this._p3 = this._p2 / _2PI * (Math.asin(1 / this._p1) || 0);
  2842. }, true),
  2843. p = c.prototype = new Ease();
  2844. p.constructor = c;
  2845. p.getRatio = f;
  2846. p.config = function(amplitude, period) {
  2847. return new c(amplitude, period);
  2848. };
  2849. return c;
  2850. },
  2851. ElasticOut = _createElastic("ElasticOut", function(p) {
  2852. return this._p1 * Math.pow(2, -10 * p) * Math.sin( (p - this._p3) * _2PI / this._p2 ) + 1;
  2853. }, 0.3),
  2854. ElasticIn = _createElastic("ElasticIn", function(p) {
  2855. return -(this._p1 * Math.pow(2, 10 * (p -= 1)) * Math.sin( (p - this._p3) * _2PI / this._p2 ));
  2856. }, 0.3),
  2857. ElasticInOut = _createElastic("ElasticInOut", function(p) {
  2858. return ((p *= 2) < 1) ? -.5 * (this._p1 * Math.pow(2, 10 * (p -= 1)) * Math.sin( (p - this._p3) * _2PI / this._p2)) : this._p1 * Math.pow(2, -10 *(p -= 1)) * Math.sin( (p - this._p3) * _2PI / this._p2 ) *.5 + 1;
  2859. }, 0.45),
  2860. //Expo
  2861. ExpoOut = _create("ExpoOut", function(p) {
  2862. return 1 - Math.pow(2, -10 * p);
  2863. }),
  2864. ExpoIn = _create("ExpoIn", function(p) {
  2865. return Math.pow(2, 10 * (p - 1)) - 0.001;
  2866. }),
  2867. ExpoInOut = _create("ExpoInOut", function(p) {
  2868. return ((p *= 2) < 1) ? 0.5 * Math.pow(2, 10 * (p - 1)) : 0.5 * (2 - Math.pow(2, -10 * (p - 1)));
  2869. }),
  2870. //Sine
  2871. _HALF_PI = Math.PI / 2,
  2872. SineOut = _create("SineOut", function(p) {
  2873. return Math.sin(p * _HALF_PI);
  2874. }),
  2875. SineIn = _create("SineIn", function(p) {
  2876. return -Math.cos(p * _HALF_PI) + 1;
  2877. }),
  2878. SineInOut = _create("SineInOut", function(p) {
  2879. return -0.5 * (Math.cos(Math.PI * p) - 1);
  2880. }),
  2881. //SlowMo
  2882. SlowMo = _class("easing.SlowMo", function(linearRatio, power, yoyoMode) {
  2883. power = (power || power === 0) ? power : 0.7;
  2884. if (linearRatio == null) {
  2885. linearRatio = 0.7;
  2886. } else if (linearRatio > 1) {
  2887. linearRatio = 1;
  2888. }
  2889. this._p = (linearRatio != 1) ? power : 0;
  2890. this._p1 = (1 - linearRatio) / 2;
  2891. this._p2 = linearRatio;
  2892. this._p3 = this._p1 + this._p2;
  2893. this._calcEnd = (yoyoMode === true);
  2894. }, true),
  2895. p = SlowMo.prototype = new Ease();
  2896. p.constructor = SlowMo;
  2897. p.getRatio = function(p) {
  2898. var r = p + (0.5 - p) * this._p;
  2899. if (p < this._p1) {
  2900. return this._calcEnd ? 1 - ((p = 1 - (p / this._p1)) * p) : r - ((p = 1 - (p / this._p1)) * p * p * p * r);
  2901. } else if (p > this._p3) {
  2902. return this._calcEnd ? 1 - (p = (p - this._p3) / this._p1) * p : r + ((p - r) * (p = (p - this._p3) / this._p1) * p * p * p);
  2903. }
  2904. return this._calcEnd ? 1 : r;
  2905. };
  2906. SlowMo.ease = new SlowMo(0.7, 0.7);
  2907. p.config = SlowMo.config = function(linearRatio, power, yoyoMode) {
  2908. return new SlowMo(linearRatio, power, yoyoMode);
  2909. };
  2910. //SteppedEase
  2911. var SteppedEase = _class("easing.SteppedEase", function(steps) {
  2912. steps = steps || 1;
  2913. this._p1 = 1 / steps;
  2914. this._p2 = steps + 1;
  2915. }, true);
  2916. p = SteppedEase.prototype = new Ease();
  2917. p.constructor = SteppedEase;
  2918. p.getRatio = function(p) {
  2919. if (p < 0) {
  2920. p = 0;
  2921. } else if (p >= 1) {
  2922. p = 0.999999999;
  2923. }
  2924. return ((this._p2 * p) >> 0) * this._p1;
  2925. };
  2926. p.config = SteppedEase.config = function(steps) {
  2927. return new SteppedEase(steps);
  2928. };
  2929. _class("easing.Bounce", {
  2930. easeOut:new BounceOut(),
  2931. easeIn:new BounceIn(),
  2932. easeInOut:new BounceInOut()
  2933. }, true);
  2934. _class("easing.Circ", {
  2935. easeOut:new CircOut(),
  2936. easeIn:new CircIn(),
  2937. easeInOut:new CircInOut()
  2938. }, true);
  2939. _class("easing.Elastic", {
  2940. easeOut:new ElasticOut(),
  2941. easeIn:new ElasticIn(),
  2942. easeInOut:new ElasticInOut()
  2943. }, true);
  2944. _class("easing.Expo", {
  2945. easeOut:new ExpoOut(),
  2946. easeIn:new ExpoIn(),
  2947. easeInOut:new ExpoInOut()
  2948. }, true);
  2949. _class("easing.Sine", {
  2950. easeOut:new SineOut(),
  2951. easeIn:new SineIn(),
  2952. easeInOut:new SineInOut()
  2953. }, true);
  2954. return {
  2955. easeOut:new BackOut(),
  2956. easeIn:new BackIn(),
  2957. easeInOut:new BackInOut()
  2958. };
  2959. }, true);
  2960. });
  2961. /*
  2962. * ----------------------------------------------------------------
  2963. * Base classes like TweenLite, SimpleTimeline, Ease, Ticker, etc. (!TweenLite)
  2964. * ----------------------------------------------------------------
  2965. */
  2966. (function(window) {
  2967. "use strict";
  2968. var _namespace = function(ns) {
  2969. var a = ns.split("."),
  2970. p = window, i;
  2971. for (i = 0; i < a.length; i++) {
  2972. p[a[i]] = p = p[a[i]] || {};
  2973. }
  2974. return p;
  2975. },
  2976. gs = _namespace("com.greensock"),
  2977. a, i, e, e2, p, _gsInit,
  2978. _classLookup = {},
  2979. //_DepClass is for defining a dependent class. ns = namespace (leaving off "com.greensock." as that's assumed), dep = an array of namespaces that are required, def = the function that will return the class definition (this function will be passed each dependency in order as soon as they arrive), global = if true, the class is added to the global scope (window) or if requirejs is being used, it will tap into that instead.
  2980. _DepClass = function(ns, dep, def, global) {
  2981. this.sc = (_classLookup[ns]) ? _classLookup[ns].sc : []; //subclasses
  2982. _classLookup[ns] = this;
  2983. this.gsClass = null;
  2984. this.def = def;
  2985. var _dep = dep || [],
  2986. _classes = [];
  2987. this.check = function(init) {
  2988. var i = _dep.length, cnt = 0, cur;
  2989. while (--i > -1) {
  2990. if ((cur = _classLookup[_dep[i]] || new _DepClass(_dep[i])).gsClass) {
  2991. _classes[i] = cur.gsClass;
  2992. } else {
  2993. cnt++;
  2994. if (init) {
  2995. cur.sc.push(this);
  2996. }
  2997. }
  2998. }
  2999. if (cnt === 0 && def) {
  3000. var a = ("com.greensock." + ns).split("."),
  3001. n = a.pop(),
  3002. cl = _namespace(a.join("."))[n] = this.gsClass = def.apply(def, _classes);
  3003. //exports to multiple environments
  3004. if (global) {
  3005. (window.GreenSockGlobals || window)[n] = cl; //provides a way to avoid global namespace pollution. By default, the main classes like TweenLite, Power1, Strong, etc. are added to window unless a GreenSockGlobals is defined. So if you want to have things added to a custom object instead, just do something like window.GreenSockGlobals = {} before loading any GreenSock files. You can even set up an alias like window.GreenSockGlobals = windows.gs = {} so that you can access everything like gs.TweenLite. Also remember that ALL classes are added to the window.com.greensock object (in their respective packages, like com.greensock.easing.Power1, com.greensock.TweenLite, etc.)
  3006. if (typeof(define) === "function" && define.amd){ //AMD
  3007. define((window.GreenSockAMDPath ? window.GreenSockAMDPath + "/" : "") + ns.split(".").join("/"), [], function() { return cl; });
  3008. } else if (typeof(module) !== "undefined" && module.exports){ //node
  3009. module.exports = cl;
  3010. }
  3011. }
  3012. for (i = 0; i < this.sc.length; i++) {
  3013. this.sc[i].check(false);
  3014. }
  3015. }
  3016. };
  3017. this.check(true);
  3018. },
  3019. //a quick way to create a class that doesn't have any dependencies. Returns the class, but first registers it in the GreenSock namespace so that other classes can grab it (other classes might be dependent on the class).
  3020. _class = gs._class = function(ns, f, g) {
  3021. new _DepClass(ns, [], function(){ return f; }, g);
  3022. return f;
  3023. };
  3024. //used to create _DepClass instances (which basically registers a class that has dependencies). ns = namespace, dep = dependencies (array), f = initialization function which should return the class, g = global (whether or not the class should be added to the global namespace (or if RequireJS is used, it will be defined as a named module instead)
  3025. window._gsDefine = function(ns, dep, f, g) {
  3026. return new _DepClass(ns, dep, f, g);
  3027. };
  3028. /*
  3029. * ----------------------------------------------------------------
  3030. * Ease
  3031. * ----------------------------------------------------------------
  3032. */
  3033. var _baseParams = [0, 0, 1, 1],
  3034. _blankArray = [],
  3035. Ease = _class("easing.Ease", function(func, extraParams, type, power) {
  3036. this._func = func;
  3037. this._type = type || 0;
  3038. this._power = power || 0;
  3039. this._params = extraParams ? _baseParams.concat(extraParams) : _baseParams;
  3040. }, true);
  3041. p = Ease.prototype;
  3042. p._calcEnd = false;
  3043. p.getRatio = function(p) {
  3044. if (this._func) {
  3045. this._params[0] = p;
  3046. return this._func.apply(null, this._params);
  3047. } else {
  3048. var t = this._type,
  3049. pw = this._power,
  3050. r = (t === 1) ? 1 - p : (t === 2) ? p : (p < 0.5) ? p * 2 : (1 - p) * 2;
  3051. if (pw === 1) {
  3052. r *= r;
  3053. } else if (pw === 2) {
  3054. r *= r * r;
  3055. } else if (pw === 3) {
  3056. r *= r * r * r;
  3057. } else if (pw === 4) {
  3058. r *= r * r * r * r;
  3059. }
  3060. return (t === 1) ? 1 - r : (t === 2) ? r : (p < 0.5) ? r / 2 : 1 - (r / 2);
  3061. }
  3062. };
  3063. //create all the standard eases like Linear, Quad, Cubic, Quart, Quint, Strong, Power0, Power1, Power2, Power3, and Power4 (each with easeIn, easeOut, and easeInOut)
  3064. a = ["Linear","Quad","Cubic","Quart","Quint"];
  3065. i = a.length;
  3066. while(--i > -1) {
  3067. e = _class("easing." + a[i], function(){}, true);
  3068. e2 = _class("easing.Power" + i, function(){}, true);
  3069. e.easeOut = e2.easeOut = new Ease(null, null, 1, i);
  3070. e.easeIn = e2.easeIn = new Ease(null, null, 2, i);
  3071. e.easeInOut = e2.easeInOut = new Ease(null, null, 3, i);
  3072. }
  3073. _class("easing.Strong", gs.easing.Power4, true);
  3074. gs.easing.Linear.easeNone = gs.easing.Linear.easeIn;
  3075. /*
  3076. * ----------------------------------------------------------------
  3077. * EventDispatcher
  3078. * ----------------------------------------------------------------
  3079. */
  3080. p = _class("events.EventDispatcher", function(target) {
  3081. this._listeners = {};
  3082. this._eventTarget = target || this;
  3083. }).prototype;
  3084. p.addEventListener = function(type, callback, scope, useParam, priority) {
  3085. priority = priority || 0;
  3086. var list = this._listeners[type],
  3087. index = 0,
  3088. listener, i;
  3089. if (list == null) {
  3090. this._listeners[type] = list = [];
  3091. }
  3092. i = list.length;
  3093. while (--i > -1) {
  3094. listener = list[i];
  3095. if (listener.c === callback) {
  3096. list.splice(i, 1);
  3097. } else if (index === 0 && listener.pr < priority) {
  3098. index = i + 1;
  3099. }
  3100. }
  3101. list.splice(index, 0, {c:callback, s:scope, up:useParam, pr:priority});
  3102. };
  3103. p.removeEventListener = function(type, callback) {
  3104. var list = this._listeners[type];
  3105. if (list) {
  3106. var i = list.length;
  3107. while (--i > -1) {
  3108. if (list[i].c === callback) {
  3109. list.splice(i, 1);
  3110. return;
  3111. }
  3112. }
  3113. }
  3114. };
  3115. p.dispatchEvent = function(type) {
  3116. var list = this._listeners[type];
  3117. if (list) {
  3118. var i = list.length, listener,
  3119. t = this._eventTarget;
  3120. while (--i > -1) {
  3121. listener = list[i];
  3122. if (listener.up) {
  3123. listener.c.call(listener.s || t, {type:type, target:t});
  3124. } else {
  3125. listener.c.call(listener.s || t);
  3126. }
  3127. }
  3128. }
  3129. };
  3130. /*
  3131. * ----------------------------------------------------------------
  3132. * Ticker
  3133. * ----------------------------------------------------------------
  3134. */
  3135. var _reqAnimFrame = window.requestAnimationFrame,
  3136. _cancelAnimFrame = window.cancelAnimationFrame,
  3137. _getTime = Date.now || function() {return new Date().getTime();};
  3138. //now try to determine the requestAnimationFrame and cancelAnimationFrame functions and if none are found, we'll use a setTimeout()/clearTimeout() polyfill.
  3139. a = ["ms","moz","webkit","o"];
  3140. i = a.length;
  3141. while (--i > -1 && !_reqAnimFrame) {
  3142. _reqAnimFrame = window[a[i] + "RequestAnimationFrame"];
  3143. _cancelAnimFrame = window[a[i] + "CancelAnimationFrame"] || window[a[i] + "CancelRequestAnimationFrame"];
  3144. }
  3145. if (!_cancelAnimFrame) {
  3146. _cancelAnimFrame = function(id) {
  3147. window.clearTimeout(id);
  3148. }
  3149. }
  3150. _class("Ticker", function(fps, useRAF) {
  3151. this.time = 0;
  3152. this.frame = 0;
  3153. var _self = this,
  3154. _startTime = _getTime(),
  3155. _useRAF = (useRAF !== false),
  3156. _fps, _req, _id, _gap, _nextTime;
  3157. this.tick = function() {
  3158. _self.time = (_getTime() - _startTime) / 1000;
  3159. if (!_fps || _self.time >= _nextTime) {
  3160. _self.frame++;
  3161. _nextTime = _self.time + _gap - (_self.time - _nextTime) - 0.0005;
  3162. if (_nextTime <= _self.time) {
  3163. _nextTime = _self.time + 0.001;
  3164. }
  3165. _self.dispatchEvent("tick");
  3166. }
  3167. _id = _req( _self.tick );
  3168. };
  3169. this.fps = function(value) {
  3170. if (!arguments.length) {
  3171. return _fps;
  3172. }
  3173. _fps = value;
  3174. _gap = 1 / (_fps || 60);
  3175. _nextTime = this.time + _gap;
  3176. _req = (_fps === 0) ? function(f){} : (!_useRAF || !_reqAnimFrame) ? function(f) { return window.setTimeout( f, (((_nextTime - _self.time) * 1000 + 1) >> 0) || 1); } : _reqAnimFrame;
  3177. _cancelAnimFrame(_id);
  3178. _id = _req( _self.tick );
  3179. };
  3180. this.useRAF = function(value) {
  3181. if (!arguments.length) {
  3182. return _useRAF
  3183. }
  3184. _useRAF = value;
  3185. this.fps(_fps);
  3186. };
  3187. this.fps(fps);
  3188. });
  3189. p = gs.Ticker.prototype = new gs.events.EventDispatcher();
  3190. p.constructor = gs.Ticker;
  3191. /*
  3192. * ----------------------------------------------------------------
  3193. * Animation
  3194. * ----------------------------------------------------------------
  3195. */
  3196. var Animation = _class("core.Animation", function(duration, vars) {
  3197. this.vars = vars || {};
  3198. this._duration = this._totalDuration = duration || 0;
  3199. this._delay = Number(this.vars.delay) || 0;
  3200. this._timeScale = 1;
  3201. this._active = (this.vars.immediateRender == true);
  3202. this.data = this.vars.data;
  3203. this._reversed = (this.vars.reversed == true);
  3204. if (!_rootTimeline) {
  3205. return;
  3206. }
  3207. if (!_gsInit) {
  3208. _ticker.tick(); //the first time an animation (tween or timeline) is created, we should refresh the time in order to avoid a gap. The Ticker's initial time that it records might be very early in the load process and the user may have loaded several other large scripts in the mean time, but we want tweens to act as though they started when the page's onload was fired. Also remember that the requestAnimationFrame likely won't be called until the first screen redraw.
  3209. _gsInit = true;
  3210. }
  3211. var tl = this.vars.useFrames ? _rootFramesTimeline : _rootTimeline;
  3212. tl.insert(this, tl._time);
  3213. if (this.vars.paused) {
  3214. this.paused(true);
  3215. }
  3216. }),
  3217. _ticker = Animation.ticker = new gs.Ticker();
  3218. p = Animation.prototype;
  3219. p._dirty = p._gc = p._initted = p._paused = false;
  3220. p._totalTime = p._time = 0;
  3221. p._rawPrevTime = -1;
  3222. p._next = p._last = p._onUpdate = p._timeline = p.timeline = null;
  3223. p._paused = false;
  3224. p.play = function(from, suppressEvents) {
  3225. if (arguments.length) {
  3226. this.seek(from, suppressEvents);
  3227. }
  3228. this.reversed(false);
  3229. return this.paused(false);
  3230. };
  3231. p.pause = function(atTime, suppressEvents) {
  3232. if (arguments.length) {
  3233. this.seek(atTime, suppressEvents);
  3234. }
  3235. return this.paused(true);
  3236. };
  3237. p.resume = function(from, suppressEvents) {
  3238. if (arguments.length) {
  3239. this.seek(from, suppressEvents);
  3240. }
  3241. return this.paused(false);
  3242. };
  3243. p.seek = function(time, suppressEvents) {
  3244. return this.totalTime(Number(time), (suppressEvents != false));
  3245. };
  3246. p.restart = function(includeDelay, suppressEvents) {
  3247. this.reversed(false);
  3248. this.paused(false);
  3249. return this.totalTime((includeDelay) ? -this._delay : 0, (suppressEvents != false));
  3250. };
  3251. p.reverse = function(from, suppressEvents) {
  3252. if (arguments.length) {
  3253. this.seek((from || this.totalDuration()), suppressEvents);
  3254. }
  3255. this.reversed(true);
  3256. return this.paused(false);
  3257. };
  3258. p.render = function() {
  3259. };
  3260. p.invalidate = function() {
  3261. return this;
  3262. };
  3263. p._enabled = function (enabled, ignoreTimeline) {
  3264. this._gc = !enabled;
  3265. this._active = (enabled && !this._paused && this._totalTime > 0 && this._totalTime < this._totalDuration);
  3266. if (ignoreTimeline != true) {
  3267. if (enabled && this.timeline == null) {
  3268. this._timeline.insert(this, this._startTime - this._delay);
  3269. } else if (!enabled && this.timeline != null) {
  3270. this._timeline._remove(this, true);
  3271. }
  3272. }
  3273. return false;
  3274. };
  3275. p._kill = function(vars, target) {
  3276. return this._enabled(false, false);
  3277. };
  3278. p.kill = function(vars, target) {
  3279. this._kill(vars, target);
  3280. return this;
  3281. };
  3282. p._uncache = function(includeSelf) {
  3283. var tween = includeSelf ? this : this.timeline;
  3284. while (tween) {
  3285. tween._dirty = true;
  3286. tween = tween.timeline;
  3287. }
  3288. return this;
  3289. };
  3290. //----Animation getters/setters --------------------------------------------------------
  3291. p.eventCallback = function(type, callback, params, scope) {
  3292. if (type == null) {
  3293. return null;
  3294. } else if (type.substr(0,2) === "on") {
  3295. if (arguments.length === 1) {
  3296. return this.vars[type];
  3297. }
  3298. if (callback == null) {
  3299. delete this.vars[type];
  3300. } else {
  3301. this.vars[type] = callback;
  3302. this.vars[type + "Params"] = params;
  3303. this.vars[type + "Scope"] = scope;
  3304. if (params) {
  3305. var i = params.length;
  3306. while (--i > -1) {
  3307. if (params[i] === "{self}") {
  3308. params = this.vars[type + "Params"] = params.concat(); //copying the array avoids situations where the same array is passed to multiple tweens/timelines and {self} doesn't correctly point to each individual instance.
  3309. params[i] = this;
  3310. }
  3311. }
  3312. }
  3313. }
  3314. if (type === "onUpdate") {
  3315. this._onUpdate = callback;
  3316. }
  3317. }
  3318. return this;
  3319. }
  3320. p.delay = function(value) {
  3321. if (!arguments.length) {
  3322. return this._delay;
  3323. }
  3324. if (this._timeline.smoothChildTiming) {
  3325. this.startTime( this._startTime + value - this._delay );
  3326. }
  3327. this._delay = value;
  3328. return this;
  3329. };
  3330. p.duration = function(value) {
  3331. if (!arguments.length) {
  3332. this._dirty = false;
  3333. return this._duration;
  3334. }
  3335. this._duration = this._totalDuration = value;
  3336. this._uncache(true); //true in case it's a TweenMax or TimelineMax that has a repeat - we'll need to refresh the totalDuration.
  3337. if (this._timeline.smoothChildTiming) if (this._active) if (value != 0) {
  3338. this.totalTime(this._totalTime * (value / this._duration), true);
  3339. }
  3340. return this;
  3341. };
  3342. p.totalDuration = function(value) {
  3343. this._dirty = false;
  3344. return (!arguments.length) ? this._totalDuration : this.duration(value);
  3345. };
  3346. p.time = function(value, suppressEvents) {
  3347. if (!arguments.length) {
  3348. return this._time;
  3349. }
  3350. if (this._dirty) {
  3351. this.totalDuration();
  3352. }
  3353. if (value > this._duration) {
  3354. value = this._duration;
  3355. }
  3356. return this.totalTime(value, suppressEvents);
  3357. };
  3358. p.totalTime = function(time, suppressEvents) {
  3359. if (!arguments.length) {
  3360. return this._totalTime;
  3361. }
  3362. if (this._timeline) {
  3363. if (time < 0) {
  3364. time += this.totalDuration();
  3365. }
  3366. if (this._timeline.smoothChildTiming) {
  3367. if (this._dirty) {
  3368. this.totalDuration();
  3369. }
  3370. if (time > this._totalDuration) {
  3371. time = this._totalDuration;
  3372. }
  3373. this._startTime = (this._paused ? this._pauseTime : this._timeline._time) - ((!this._reversed ? time : this._totalDuration - time) / this._timeScale);
  3374. if (!this._timeline._dirty) { //for performance improvement. If the parent's cache is already dirty, it already took care of marking the anscestors as dirty too, so skip the function call here.
  3375. this._uncache(false);
  3376. }
  3377. if (!this._timeline._active) {
  3378. //in case any of the anscestors had completed but should now be enabled...
  3379. var tl = this._timeline;
  3380. while (tl._timeline) {
  3381. tl.totalTime(tl._totalTime, true);
  3382. tl = tl._timeline;
  3383. }
  3384. }
  3385. }
  3386. if (this._gc) {
  3387. this._enabled(true, false);
  3388. }
  3389. if (this._totalTime != time) {
  3390. this.render(time, suppressEvents, false);
  3391. }
  3392. }
  3393. return this;
  3394. };
  3395. p.startTime = function(value) {
  3396. if (!arguments.length) {
  3397. return this._startTime;
  3398. }
  3399. if (value != this._startTime) {
  3400. this._startTime = value;
  3401. if (this.timeline) if (this.timeline._sortChildren) {
  3402. this.timeline.insert(this, value - this._delay); //ensures that any necessary re-sequencing of Animations in the timeline occurs to make sure the rendering order is correct.
  3403. }
  3404. }
  3405. return this;
  3406. };
  3407. p.timeScale = function(value) {
  3408. if (!arguments.length) {
  3409. return this._timeScale;
  3410. }
  3411. value = value || 0.000001; //can't allow zero because it'll throw the math off
  3412. if (this._timeline && this._timeline.smoothChildTiming) {
  3413. var t = (this._pauseTime || this._pauseTime == 0) ? this._pauseTime : this._timeline._totalTime;
  3414. this._startTime = t - ((t - this._startTime) * this._timeScale / value);
  3415. }
  3416. this._timeScale = value;
  3417. return this._uncache(false);
  3418. };
  3419. p.reversed = function(value) {
  3420. if (!arguments.length) {
  3421. return this._reversed;
  3422. }
  3423. if (value != this._reversed) {
  3424. this._reversed = value;
  3425. this.totalTime(this._totalTime, true);
  3426. }
  3427. return this;
  3428. };
  3429. p.paused = function(value) {
  3430. if (!arguments.length) {
  3431. return this._paused;
  3432. }
  3433. if (value != this._paused) if (this._timeline) {
  3434. if (!value && this._timeline.smoothChildTiming) {
  3435. this._startTime += this._timeline.rawTime() - this._pauseTime;
  3436. this._uncache(false);
  3437. }
  3438. this._pauseTime = (value) ? this._timeline.rawTime() : null;
  3439. this._paused = value;
  3440. this._active = (!this._paused && this._totalTime > 0 && this._totalTime < this._totalDuration);
  3441. }
  3442. if (this._gc) if (!value) {
  3443. this._enabled(true, false);
  3444. }
  3445. return this;
  3446. };
  3447. /*
  3448. * ----------------------------------------------------------------
  3449. * SimpleTimeline
  3450. * ----------------------------------------------------------------
  3451. */
  3452. var SimpleTimeline = _class("core.SimpleTimeline", function(vars) {
  3453. Animation.call(this, 0, vars);
  3454. this.autoRemoveChildren = this.smoothChildTiming = true;
  3455. });
  3456. p = SimpleTimeline.prototype = new Animation();
  3457. p.constructor = SimpleTimeline;
  3458. p.kill()._gc = false;
  3459. p._first = p._last = null;
  3460. p._sortChildren = false;
  3461. p.insert = function(tween, time) {
  3462. tween._startTime = Number(time || 0) + tween._delay;
  3463. if (tween._paused) if (this !== tween._timeline) { //we only adjust the _pauseTime if it wasn't in this timeline already. Remember, sometimes a tween will be inserted again into the same timeline when its startTime is changed so that the tweens in the TimelineLite/Max are re-ordered properly in the linked list (so everything renders in the proper order).
  3464. tween._pauseTime = tween._startTime + ((this.rawTime() - tween._startTime) / tween._timeScale);
  3465. }
  3466. if (tween.timeline) {
  3467. tween.timeline._remove(tween, true); //removes from existing timeline so that it can be properly added to this one.
  3468. }
  3469. tween.timeline = tween._timeline = this;
  3470. if (tween._gc) {
  3471. tween._enabled(true, true);
  3472. }
  3473. var prevTween = this._last;
  3474. if (this._sortChildren) {
  3475. var st = tween._startTime;
  3476. while (prevTween && prevTween._startTime > st) {
  3477. prevTween = prevTween._prev;
  3478. }
  3479. }
  3480. if (prevTween) {
  3481. tween._next = prevTween._next;
  3482. prevTween._next = tween;
  3483. } else {
  3484. tween._next = this._first;
  3485. this._first = tween;
  3486. }
  3487. if (tween._next) {
  3488. tween._next._prev = tween;
  3489. } else {
  3490. this._last = tween;
  3491. }
  3492. tween._prev = prevTween;
  3493. if (this._timeline) {
  3494. this._uncache(true);
  3495. }
  3496. return this;
  3497. };
  3498. p._remove = function(tween, skipDisable) {
  3499. if (tween.timeline === this) {
  3500. if (!skipDisable) {
  3501. tween._enabled(false, true);
  3502. }
  3503. tween.timeline = null;
  3504. if (tween._prev) {
  3505. tween._prev._next = tween._next;
  3506. } else if (this._first === tween) {
  3507. this._first = tween._next;
  3508. }
  3509. if (tween._next) {
  3510. tween._next._prev = tween._prev;
  3511. } else if (this._last === tween) {
  3512. this._last = tween._prev;
  3513. }
  3514. if (this._timeline) {
  3515. this._uncache(true);
  3516. }
  3517. }
  3518. return this;
  3519. };
  3520. p.render = function(time, suppressEvents, force) {
  3521. var tween = this._first,
  3522. next;
  3523. this._totalTime = this._time = this._rawPrevTime = time;
  3524. while (tween) {
  3525. next = tween._next; //record it here because the value could change after rendering...
  3526. if (tween._active || (time >= tween._startTime && !tween._paused)) {
  3527. if (!tween._reversed) {
  3528. tween.render((time - tween._startTime) * tween._timeScale, suppressEvents, false);
  3529. } else {
  3530. tween.render(((!tween._dirty) ? tween._totalDuration : tween.totalDuration()) - ((time - tween._startTime) * tween._timeScale), suppressEvents, false);
  3531. }
  3532. }
  3533. tween = next;
  3534. }
  3535. };
  3536. p.rawTime = function() {
  3537. return this._totalTime;
  3538. };
  3539. /*
  3540. * ----------------------------------------------------------------
  3541. * TweenLite
  3542. * ----------------------------------------------------------------
  3543. */
  3544. var TweenLite = _class("TweenLite", function(target, duration, vars) {
  3545. Animation.call(this, duration, vars);
  3546. if (target == null) {
  3547. throw "Cannot tween an undefined reference.";
  3548. }
  3549. this.target = target;
  3550. this._overwrite = (this.vars.overwrite == null) ? _overwriteLookup[TweenLite.defaultOverwrite] : (typeof(this.vars.overwrite) === "number") ? this.vars.overwrite >> 0 : _overwriteLookup[this.vars.overwrite];
  3551. var jq, i, targ;
  3552. if ((target instanceof Array || target.jquery) && typeof(target[0]) === "object") {
  3553. this._targets = target.slice(0); //works for both jQuery and Array instances
  3554. this._propLookup = [];
  3555. this._siblings = [];
  3556. for (i = 0; i < this._targets.length; i++) {
  3557. targ = this._targets[i];
  3558. //in case the user is passing in an array of jQuery objects, for example, we need to check one more level and pull things out if necessary...
  3559. if (targ.jquery) {
  3560. this._targets.splice(i--, 1);
  3561. this._targets = this._targets.concat(targ.constructor.makeArray(targ));
  3562. continue;
  3563. }
  3564. this._siblings[i] = _register(targ, this, false);
  3565. if (this._overwrite === 1) if (this._siblings[i].length > 1) {
  3566. _applyOverwrite(targ, this, null, 1, this._siblings[i]);
  3567. }
  3568. }
  3569. } else {
  3570. this._propLookup = {};
  3571. this._siblings = _register(target, this, false);
  3572. if (this._overwrite === 1) if (this._siblings.length > 1) {
  3573. _applyOverwrite(target, this, null, 1, this._siblings);
  3574. }
  3575. }
  3576. if (this.vars.immediateRender || (duration === 0 && this._delay === 0 && this.vars.immediateRender != false)) {
  3577. this.render(-this._delay, false, true);
  3578. }
  3579. }, true);
  3580. p = TweenLite.prototype = new Animation();
  3581. p.constructor = TweenLite;
  3582. p.kill()._gc = false;
  3583. //----TweenLite defaults, overwrite management, and root updates ----------------------------------------------------
  3584. p.ratio = 0;
  3585. p._firstPT = p._targets = p._overwrittenProps = null;
  3586. p._notifyPluginsOfEnabled = false;
  3587. TweenLite.version = 12;
  3588. TweenLite.defaultEase = p._ease = new Ease(null, null, 1, 1);
  3589. TweenLite.defaultOverwrite = "auto";
  3590. TweenLite.ticker = _ticker;
  3591. var _plugins = TweenLite._plugins = {},
  3592. _tweenLookup = TweenLite._tweenLookup = {},
  3593. _tweenLookupNum = 0,
  3594. _reservedProps = {ease:1, delay:1, overwrite:1, onComplete:1, onCompleteParams:1, onCompleteScope:1, useFrames:1, runBackwards:1, startAt:1, onUpdate:1, onUpdateParams:1, onUpdateScope:1, onStart:1, onStartParams:1, onStartScope:1, onReverseComplete:1, onReverseCompleteParams:1, onReverseCompleteScope:1, onRepeat:1, onRepeatParams:1, onRepeatScope:1, easeParams:1, yoyo:1, orientToBezier:1, immediateRender:1, repeat:1, repeatDelay:1, data:1, paused:1, reversed:1},
  3595. _overwriteLookup = {none:0, all:1, auto:2, concurrent:3, allOnStart:4, preexisting:5, "true":1, "false":0},
  3596. _rootFramesTimeline = Animation._rootFramesTimeline = new SimpleTimeline(),
  3597. _rootTimeline = Animation._rootTimeline = new SimpleTimeline();
  3598. _rootTimeline._startTime = _ticker.time;
  3599. _rootFramesTimeline._startTime = _ticker.frame;
  3600. _rootTimeline._active = _rootFramesTimeline._active = true;
  3601. Animation._updateRoot = function() {
  3602. _rootTimeline.render((_ticker.time - _rootTimeline._startTime) * _rootTimeline._timeScale, false, false);
  3603. _rootFramesTimeline.render((_ticker.frame - _rootFramesTimeline._startTime) * _rootFramesTimeline._timeScale, false, false);
  3604. if (!(_ticker.frame % 120)) { //dump garbage every 120 frames...
  3605. var i, a, p;
  3606. for (p in _tweenLookup) {
  3607. a = _tweenLookup[p].tweens;
  3608. i = a.length;
  3609. while (--i > -1) {
  3610. if (a[i]._gc) {
  3611. a.splice(i, 1);
  3612. }
  3613. }
  3614. if (a.length === 0) {
  3615. delete _tweenLookup[p];
  3616. }
  3617. }
  3618. }
  3619. };
  3620. _ticker.addEventListener("tick", Animation._updateRoot);
  3621. var _register = function(target, tween, scrub) {
  3622. var id = target._gsTweenID, a, i;
  3623. if (!_tweenLookup[id || (target._gsTweenID = id = "t" + (_tweenLookupNum++))]) {
  3624. _tweenLookup[id] = {target:target, tweens:[]};
  3625. }
  3626. if (tween) {
  3627. a = _tweenLookup[id].tweens;
  3628. a[(i = a.length)] = tween;
  3629. if (scrub) {
  3630. while (--i > -1) {
  3631. if (a[i] === tween) {
  3632. a.splice(i, 1);
  3633. }
  3634. }
  3635. }
  3636. }
  3637. return _tweenLookup[id].tweens;
  3638. },
  3639. _applyOverwrite = function(target, tween, props, mode, siblings) {
  3640. var i, changed, curTween;
  3641. if (mode === 1 || mode >= 4) {
  3642. var l = siblings.length;
  3643. for (i = 0; i < l; i++) {
  3644. if ((curTween = siblings[i]) !== tween) {
  3645. if (!curTween._gc) if (curTween._enabled(false, false)) {
  3646. changed = true;
  3647. }
  3648. } else if (mode === 5) {
  3649. break;
  3650. }
  3651. }
  3652. return changed;
  3653. }
  3654. //NOTE: Add 0.0000000001 to overcome floating point errors that can cause the startTime to be VERY slightly off (when a tween's time() is set for example)
  3655. var startTime = tween._startTime + 0.0000000001,
  3656. overlaps = [],
  3657. oCount = 0,
  3658. globalStart;
  3659. i = siblings.length;
  3660. while (--i > -1) {
  3661. if ((curTween = siblings[i]) === tween || curTween._gc || curTween._paused) {
  3662. //ignore
  3663. } else if (curTween._timeline !== tween._timeline) {
  3664. globalStart = globalStart || _checkOverlap(tween, 0);
  3665. if (_checkOverlap(curTween, globalStart) === 0) {
  3666. overlaps[oCount++] = curTween;
  3667. }
  3668. } else if (curTween._startTime <= startTime) if (curTween._startTime + curTween.totalDuration() / curTween._timeScale + 0.0000000001 > startTime) if (!((tween._duration === 0 || !curTween._initted) && startTime - curTween._startTime <= 0.0000000002)) {
  3669. overlaps[oCount++] = curTween;
  3670. }
  3671. }
  3672. i = oCount;
  3673. while (--i > -1) {
  3674. curTween = overlaps[i];
  3675. if (mode === 2) if (curTween._kill(props, target)) {
  3676. changed = true;
  3677. }
  3678. if (mode !== 2 || (!curTween._firstPT && curTween._initted)) {
  3679. if (curTween._enabled(false, false)) { //if all property tweens have been overwritten, kill the tween.
  3680. changed = true;
  3681. }
  3682. }
  3683. }
  3684. return changed;
  3685. },
  3686. _checkOverlap = function(tween, reference) {
  3687. var tl = tween._timeline,
  3688. ts = tl._timeScale,
  3689. t = tween._startTime;
  3690. while (tl._timeline) {
  3691. t += tl._startTime;
  3692. ts *= tl._timeScale;
  3693. if (tl._paused) {
  3694. return -100;
  3695. }
  3696. tl = tl._timeline;
  3697. }
  3698. t /= ts;
  3699. return (t > reference) ? t - reference : (!tween._initted && t - reference < 0.0000000002) ? 0.0000000001 : ((t = t + tween.totalDuration() / tween._timeScale / ts) > reference) ? 0 : t - reference - 0.0000000001;
  3700. };
  3701. //---- TweenLite instance methods -----------------------------------------------------------------------------
  3702. p._init = function() {
  3703. if (this.vars.startAt) {
  3704. this.vars.startAt.overwrite = 0;
  3705. this.vars.startAt.immediateRender = true;
  3706. TweenLite.to(this.target, 0, this.vars.startAt);
  3707. }
  3708. var i, initPlugins, pt;
  3709. if (this.vars.ease instanceof Ease) {
  3710. this._ease = (this.vars.easeParams instanceof Array) ? this.vars.ease.config.apply(this.vars.ease, this.vars.easeParams) : this.vars.ease;
  3711. } else if (typeof(this.vars.ease) === "function") {
  3712. this._ease = new Ease(this.vars.ease, this.vars.easeParams);
  3713. } else {
  3714. this._ease = TweenLite.defaultEase;
  3715. }
  3716. this._easeType = this._ease._type;
  3717. this._easePower = this._ease._power;
  3718. this._firstPT = null;
  3719. if (this._targets) {
  3720. i = this._targets.length;
  3721. while (--i > -1) {
  3722. if ( this._initProps( this._targets[i], (this._propLookup[i] = {}), this._siblings[i], (this._overwrittenProps ? this._overwrittenProps[i] : null)) ) {
  3723. initPlugins = true;
  3724. }
  3725. }
  3726. } else {
  3727. initPlugins = this._initProps(this.target, this._propLookup, this._siblings, this._overwrittenProps);
  3728. }
  3729. if (initPlugins) {
  3730. TweenLite._onPluginEvent("_onInitAllProps", this); //reorders the array in order of priority. Uses a static TweenPlugin method in order to minimize file size in TweenLite
  3731. }
  3732. if (this._overwrittenProps) if (this._firstPT == null) if (typeof(this.target) !== "function") { //if all tweening properties have been overwritten, kill the tween. If the target is a function, it's probably a delayedCall so let it live.
  3733. this._enabled(false, false);
  3734. }
  3735. if (this.vars.runBackwards) {
  3736. pt = this._firstPT;
  3737. while (pt) {
  3738. pt.s += pt.c;
  3739. pt.c = -pt.c;
  3740. pt = pt._next;
  3741. }
  3742. }
  3743. this._onUpdate = this.vars.onUpdate;
  3744. this._initted = true;
  3745. };
  3746. p._initProps = function(target, propLookup, siblings, overwrittenProps) {
  3747. var p, i, initPlugins, plugin, a, pt;
  3748. if (target == null) {
  3749. return false;
  3750. }
  3751. for (p in this.vars) {
  3752. if (_reservedProps[p]) {
  3753. if (p === "onStartParams" || p === "onUpdateParams" || p === "onCompleteParams" || p === "onReverseCompleteParams" || p === "onRepeatParams") if ((a = this.vars[p])) {
  3754. i = a.length;
  3755. while (--i > -1) {
  3756. if (a[i] === "{self}") {
  3757. a = this.vars[p] = a.concat(); //copy the array in case the user referenced the same array in multiple tweens/timelines (each {self} should be unique)
  3758. a[i] = this;
  3759. }
  3760. }
  3761. }
  3762. } else if (_plugins[p] && (plugin = new _plugins[p]())._onInitTween(target, this.vars[p], this)) {
  3763. //t - target [object]
  3764. //p - property [string]
  3765. //s - start [number]
  3766. //c - change [number]
  3767. //f - isFunction [boolean]
  3768. //n - name [string]
  3769. //pg - isPlugin [boolean]
  3770. //pr - priority [number]
  3771. this._firstPT = pt = {_next:this._firstPT, t:plugin, p:"setRatio", s:0, c:1, f:true, n:p, pg:true, pr:plugin._priority};
  3772. i = plugin._overwriteProps.length;
  3773. while (--i > -1) {
  3774. propLookup[plugin._overwriteProps[i]] = this._firstPT;
  3775. }
  3776. if (plugin._priority || plugin._onInitAllProps) {
  3777. initPlugins = true;
  3778. }
  3779. if (plugin._onDisable || plugin._onEnable) {
  3780. this._notifyPluginsOfEnabled = true;
  3781. }
  3782. } else {
  3783. this._firstPT = propLookup[p] = pt = {_next:this._firstPT, t:target, p:p, f:(typeof(target[p]) === "function"), n:p, pg:false, pr:0};
  3784. pt.s = (!pt.f) ? parseFloat(target[p]) : target[ ((p.indexOf("set") || typeof(target["get" + p.substr(3)]) !== "function") ? p : "get" + p.substr(3)) ]();
  3785. pt.c = (typeof(this.vars[p]) === "number") ? this.vars[p] - pt.s : (typeof(this.vars[p]) === "string") ? parseFloat(this.vars[p].split("=").join("")) : 0;
  3786. }
  3787. if (pt) if (pt._next) {
  3788. pt._next._prev = pt;
  3789. }
  3790. }
  3791. if (overwrittenProps) if (this._kill(overwrittenProps, target)) { //another tween may have tried to overwrite properties of this tween before init() was called (like if two tweens start at the same time, the one created second will run first)
  3792. return this._initProps(target, propLookup, siblings, overwrittenProps);
  3793. }
  3794. if (this._overwrite > 1) if (this._firstPT) if (siblings.length > 1) if (_applyOverwrite(target, this, propLookup, this._overwrite, siblings)) {
  3795. this._kill(propLookup, target);
  3796. return this._initProps(target, propLookup, siblings, overwrittenProps);
  3797. }
  3798. return initPlugins;
  3799. };
  3800. p.render = function(time, suppressEvents, force) {
  3801. var prevTime = this._time,
  3802. isComplete, callback, pt;
  3803. if (time >= this._duration) {
  3804. this._totalTime = this._time = this._duration;
  3805. this.ratio = this._ease._calcEnd ? this._ease.getRatio(1) : 1;
  3806. if (!this._reversed) {
  3807. isComplete = true;
  3808. callback = "onComplete";
  3809. }
  3810. if (this._duration === 0) { //zero-duration tweens are tricky because we must discern the momentum/direction of time in order to determine whether the starting values should be rendered or the ending values. If the "playhead" of its timeline goes past the zero-duration tween in the forward direction or lands directly on it, the end values should be rendered, but if the timeline's "playhead" moves past it in the backward direction (from a postitive time to a negative time), the starting values must be rendered.
  3811. if (time === 0 || this._rawPrevTime < 0) if (this._rawPrevTime !== time) {
  3812. force = true;
  3813. }
  3814. this._rawPrevTime = time;
  3815. }
  3816. } else if (time <= 0) {
  3817. this._totalTime = this._time = 0;
  3818. this.ratio = this._ease._calcEnd ? this._ease.getRatio(0) : 0;
  3819. if (prevTime !== 0 || (this._duration === 0 && this._rawPrevTime > 0)) {
  3820. callback = "onReverseComplete";
  3821. isComplete = this._reversed;
  3822. }
  3823. if (time < 0) {
  3824. this._active = false;
  3825. if (this._duration === 0) { //zero-duration tweens are tricky because we must discern the momentum/direction of time in order to determine whether the starting values should be rendered or the ending values. If the "playhead" of its timeline goes past the zero-duration tween in the forward direction or lands directly on it, the end values should be rendered, but if the timeline's "playhead" moves past it in the backward direction (from a postitive time to a negative time), the starting values must be rendered.
  3826. if (this._rawPrevTime >= 0) {
  3827. force = true;
  3828. }
  3829. this._rawPrevTime = time;
  3830. }
  3831. } else if (!this._initted) { //if we render the very beginning (time == 0) of a fromTo(), we must force the render (normal tweens wouldn't need to render at a time of 0 when the prevTime was also 0). This is also mandatory to make sure overwriting kicks in immediately.
  3832. force = true;
  3833. }
  3834. } else {
  3835. this._totalTime = this._time = time;
  3836. if (this._easeType) {
  3837. var r = time / this._duration, type = this._easeType, pow = this._easePower;
  3838. if (type === 1 || (type === 3 && r >= 0.5)) {
  3839. r = 1 - r;
  3840. }
  3841. if (type === 3) {
  3842. r *= 2;
  3843. }
  3844. if (pow === 1) {
  3845. r *= r;
  3846. } else if (pow === 2) {
  3847. r *= r * r;
  3848. } else if (pow === 3) {
  3849. r *= r * r * r;
  3850. } else if (pow === 4) {
  3851. r *= r * r * r * r;
  3852. }
  3853. if (type === 1) {
  3854. this.ratio = 1 - r;
  3855. } else if (type === 2) {
  3856. this.ratio = r;
  3857. } else if (time / this._duration < 0.5) {
  3858. this.ratio = r / 2;
  3859. } else {
  3860. this.ratio = 1 - (r / 2);
  3861. }
  3862. } else {
  3863. this.ratio = this._ease.getRatio(time / this._duration);
  3864. }
  3865. }
  3866. if (this._time === prevTime && !force) {
  3867. return;
  3868. } else if (!this._initted) {
  3869. this._init();
  3870. if (!isComplete && this._time) { //_ease is initially set to defaultEase, so now that init() has run, _ease is set properly and we need to recalculate the ratio. Overall this is faster than using conditional logic earlier in the method to avoid having to set ratio twice because we only init() once but renderTime() gets called VERY frequently.
  3871. this.ratio = this._ease.getRatio(this._time / this._duration);
  3872. }
  3873. }
  3874. if (!this._active) if (!this._paused) {
  3875. this._active = true; //so that if the user renders a tween (as opposed to the timeline rendering it), the timeline is forced to re-render and align it with the proper time/frame on the next rendering cycle. Maybe the tween already finished but the user manually re-renders it as halfway done.
  3876. }
  3877. if (prevTime === 0) if (this.vars.onStart) if (this._time !== 0 || this._duration === 0) if (!suppressEvents) {
  3878. this.vars.onStart.apply(this.vars.onStartScope || this, this.vars.onStartParams || _blankArray);
  3879. }
  3880. pt = this._firstPT;
  3881. while (pt) {
  3882. if (pt.f) {
  3883. pt.t[pt.p](pt.c * this.ratio + pt.s);
  3884. } else {
  3885. pt.t[pt.p] = pt.c * this.ratio + pt.s;
  3886. }
  3887. pt = pt._next;
  3888. }
  3889. if (this._onUpdate) if (!suppressEvents) {
  3890. this._onUpdate.apply(this.vars.onUpdateScope || this, this.vars.onUpdateParams || _blankArray);
  3891. }
  3892. if (callback) if (!this._gc) { //check _gc because there's a chance that kill() could be called in an onUpdate
  3893. if (isComplete) {
  3894. if (this._timeline.autoRemoveChildren) {
  3895. this._enabled(false, false);
  3896. }
  3897. this._active = false;
  3898. }
  3899. if (!suppressEvents) if (this.vars[callback]) {
  3900. this.vars[callback].apply(this.vars[callback + "Scope"] || this, this.vars[callback + "Params"] || _blankArray);
  3901. }
  3902. }
  3903. };
  3904. p._kill = function(vars, target) {
  3905. if (vars === "all") {
  3906. vars = null;
  3907. }
  3908. if (vars == null) if (target == null || target == this.target) {
  3909. return this._enabled(false, false);
  3910. }
  3911. target = target || this._targets || this.target;
  3912. var i, overwrittenProps, p, pt, propLookup, changed, killProps, record;
  3913. if ((target instanceof Array || target.jquery) && typeof(target[0]) === "object") {
  3914. i = target.length;
  3915. while (--i > -1) {
  3916. if (this._kill(vars, target[i])) {
  3917. changed = true;
  3918. }
  3919. }
  3920. } else {
  3921. if (this._targets) {
  3922. i = this._targets.length;
  3923. while (--i > -1) {
  3924. if (target === this._targets[i]) {
  3925. propLookup = this._propLookup[i] || {};
  3926. this._overwrittenProps = this._overwrittenProps || [];
  3927. overwrittenProps = this._overwrittenProps[i] = vars ? this._overwrittenProps[i] || {} : "all";
  3928. break;
  3929. }
  3930. }
  3931. } else if (target !== this.target) {
  3932. return false;
  3933. } else {
  3934. propLookup = this._propLookup;
  3935. overwrittenProps = this._overwrittenProps = vars ? this._overwrittenProps || {} : "all";
  3936. }
  3937. if (propLookup) {
  3938. killProps = vars || propLookup;
  3939. record = (vars != overwrittenProps && overwrittenProps != "all" && vars != propLookup && (vars == null || vars._tempKill != true)); //_tempKill is a super-secret way to delete a particular tweening property but NOT have it remembered as an official overwritten property (like in BezierPlugin)
  3940. for (p in killProps) {
  3941. if ((pt = propLookup[p])) {
  3942. if (pt.pg && pt.t._kill(killProps)) {
  3943. changed = true; //some plugins need to be notified so they can perform cleanup tasks first
  3944. }
  3945. if (!pt.pg || pt.t._overwriteProps.length === 0) {
  3946. if (pt._prev) {
  3947. pt._prev._next = pt._next;
  3948. } else if (pt === this._firstPT) {
  3949. this._firstPT = pt._next;
  3950. }
  3951. if (pt._next) {
  3952. pt._next._prev = pt._prev;
  3953. }
  3954. pt._next = pt._prev = null;
  3955. }
  3956. delete propLookup[p];
  3957. }
  3958. if (record) {
  3959. overwrittenProps[p] = 1;
  3960. }
  3961. }
  3962. }
  3963. }
  3964. return changed;
  3965. };
  3966. p.invalidate = function() {
  3967. if (this._notifyPluginsOfEnabled) {
  3968. TweenLite._onPluginEvent("_onDisable", this);
  3969. }
  3970. this._firstPT = null;
  3971. this._overwrittenProps = null;
  3972. this._onUpdate = null;
  3973. this._initted = this._active = this._notifyPluginsOfEnabled = false;
  3974. this._propLookup = (this._targets) ? {} : [];
  3975. return this;
  3976. };
  3977. p._enabled = function(enabled, ignoreTimeline) {
  3978. if (enabled && this._gc) {
  3979. if (this._targets) {
  3980. var i = this._targets.length;
  3981. while (--i > -1) {
  3982. this._siblings[i] = _register(this._targets[i], this, true);
  3983. }
  3984. } else {
  3985. this._siblings = _register(this.target, this, true);
  3986. }
  3987. }
  3988. Animation.prototype._enabled.call(this, enabled, ignoreTimeline);
  3989. if (this._notifyPluginsOfEnabled) if (this._firstPT) {
  3990. return TweenLite._onPluginEvent(((enabled) ? "_onEnable" : "_onDisable"), this);
  3991. }
  3992. return false;
  3993. };
  3994. //----TweenLite static methods -----------------------------------------------------
  3995. TweenLite.to = function(target, duration, vars) {
  3996. return new TweenLite(target, duration, vars);
  3997. };
  3998. TweenLite.from = function(target, duration, vars) {
  3999. vars.runBackwards = true;
  4000. if (vars.immediateRender != false) {
  4001. vars.immediateRender = true;
  4002. }
  4003. return new TweenLite(target, duration, vars);
  4004. };
  4005. TweenLite.fromTo = function(target, duration, fromVars, toVars) {
  4006. toVars.startAt = fromVars;
  4007. if (fromVars.immediateRender) {
  4008. toVars.immediateRender = true;
  4009. }
  4010. return new TweenLite(target, duration, toVars);
  4011. };
  4012. TweenLite.delayedCall = function(delay, callback, params, scope, useFrames) {
  4013. return new TweenLite(callback, 0, {delay:delay, onComplete:callback, onCompleteParams:params, onCompleteScope:scope, onReverseComplete:callback, onReverseCompleteParams:params, onReverseCompleteScope:scope, immediateRender:false, useFrames:useFrames, overwrite:0});
  4014. };
  4015. TweenLite.set = function(target, vars) {
  4016. return new TweenLite(target, 0, vars);
  4017. };
  4018. TweenLite.killTweensOf = TweenLite.killDelayedCallsTo = function(target, vars) {
  4019. var a = TweenLite.getTweensOf(target),
  4020. i = a.length;
  4021. while (--i > -1) {
  4022. a[i]._kill(vars, target);
  4023. }
  4024. };
  4025. TweenLite.getTweensOf = function(target) {
  4026. if (target == null) { return; }
  4027. var i, a, j, t;
  4028. if ((target instanceof Array || target.jquery) && typeof(target[0]) === "object") {
  4029. i = target.length;
  4030. a = [];
  4031. while (--i > -1) {
  4032. a = a.concat(TweenLite.getTweensOf(target[i]));
  4033. }
  4034. i = a.length;
  4035. //now get rid of any duplicates (tweens of arrays of objects could cause duplicates)
  4036. while (--i > -1) {
  4037. t = a[i];
  4038. j = i;
  4039. while (--j > -1) {
  4040. if (t === a[j]) {
  4041. a.splice(i, 1);
  4042. }
  4043. }
  4044. }
  4045. } else {
  4046. a = _register(target).concat();
  4047. i = a.length;
  4048. while (--i > -1) {
  4049. if (a[i]._gc) {
  4050. a.splice(i, 1);
  4051. }
  4052. }
  4053. }
  4054. return a;
  4055. };
  4056. /*
  4057. * ----------------------------------------------------------------
  4058. * TweenPlugin (could easily be split out as a separate file/class, but included for ease of use (so that people don't need to include another <script> call before loading plugins which is easy to forget)
  4059. * ----------------------------------------------------------------
  4060. */
  4061. var TweenPlugin = _class("plugins.TweenPlugin", function(props, priority) {
  4062. this._overwriteProps = (props || "").split(",");
  4063. this._propName = this._overwriteProps[0];
  4064. this._priority = priority || 0;
  4065. }, true);
  4066. p = TweenPlugin.prototype;
  4067. TweenPlugin.version = 12;
  4068. TweenPlugin.API = 2;
  4069. p._firstPT = null;
  4070. p._addTween = function(target, prop, start, end, overwriteProp, round) {
  4071. var c;
  4072. if (end != null && (c = (typeof(end) === "number" || end.charAt(1) !== "=") ? Number(end) - start : Number(end.split("=").join("")))) {
  4073. this._firstPT = {_next:this._firstPT, t:target, p:prop, s:start, c:c, f:(typeof(target[prop]) === "function"), n:overwriteProp || prop, r:round};
  4074. if (this._firstPT._next) {
  4075. this._firstPT._next._prev = this._firstPT;
  4076. }
  4077. }
  4078. }
  4079. p.setRatio = function(v) {
  4080. var pt = this._firstPT,
  4081. val;
  4082. while (pt) {
  4083. val = pt.c * v + pt.s;
  4084. if (pt.r) {
  4085. val = (val + ((val > 0) ? 0.5 : -0.5)) >> 0; //about 4x faster than Math.round()
  4086. }
  4087. if (pt.f) {
  4088. pt.t[pt.p](val);
  4089. } else {
  4090. pt.t[pt.p] = val;
  4091. }
  4092. pt = pt._next;
  4093. }
  4094. }
  4095. p._kill = function(lookup) {
  4096. if (lookup[this._propName] != null) {
  4097. this._overwriteProps = [];
  4098. } else {
  4099. var i = this._overwriteProps.length;
  4100. while (--i > -1) {
  4101. if (lookup[this._overwriteProps[i]] != null) {
  4102. this._overwriteProps.splice(i, 1);
  4103. }
  4104. }
  4105. }
  4106. var pt = this._firstPT;
  4107. while (pt) {
  4108. if (lookup[pt.n] != null) {
  4109. if (pt._next) {
  4110. pt._next._prev = pt._prev;
  4111. }
  4112. if (pt._prev) {
  4113. pt._prev._next = pt._next;
  4114. pt._prev = null;
  4115. } else if (this._firstPT === pt) {
  4116. this._firstPT = pt._next;
  4117. }
  4118. }
  4119. pt = pt._next;
  4120. }
  4121. return false;
  4122. }
  4123. p._roundProps = function(lookup, value) {
  4124. var pt = this._firstPT;
  4125. while (pt) {
  4126. if (lookup[this._propName] || (pt.n != null && lookup[ pt.n.split(this._propName + "_").join("") ])) { //some properties that are very plugin-specific add a prefix named after the _propName plus an underscore, so we need to ignore that extra stuff here.
  4127. pt.r = value;
  4128. }
  4129. pt = pt._next;
  4130. }
  4131. }
  4132. TweenLite._onPluginEvent = function(type, tween) {
  4133. var pt = tween._firstPT,
  4134. changed;
  4135. if (type === "_onInitAllProps") {
  4136. //sorts the PropTween linked list in order of priority because some plugins need to render earlier/later than others, like MotionBlurPlugin applies its effects after all x/y/alpha tweens have rendered on each frame.
  4137. var pt2, first, last, next;
  4138. while (pt) {
  4139. next = pt._next;
  4140. pt2 = first;
  4141. while (pt2 && pt2.pr > pt.pr) {
  4142. pt2 = pt2._next;
  4143. }
  4144. if ((pt._prev = pt2 ? pt2._prev : last)) {
  4145. pt._prev._next = pt;
  4146. } else {
  4147. first = pt;
  4148. }
  4149. if ((pt._next = pt2)) {
  4150. pt2._prev = pt;
  4151. } else {
  4152. last = pt;
  4153. }
  4154. pt = next;
  4155. }
  4156. pt = tween._firstPT = first;
  4157. }
  4158. while (pt) {
  4159. if (pt.pg) if (typeof(pt.t[type]) === "function") if (pt.t[type]()) {
  4160. changed = true;
  4161. }
  4162. pt = pt._next;
  4163. }
  4164. return changed;
  4165. }
  4166. TweenPlugin.activate = function(plugins) {
  4167. var i = plugins.length;
  4168. while (--i > -1) {
  4169. if (plugins[i].API === TweenPlugin.API) {
  4170. TweenLite._plugins[(new plugins[i]())._propName] = plugins[i];
  4171. }
  4172. }
  4173. return true;
  4174. }
  4175. //now run through all the dependencies discovered and if any are missing, log that to the console as a warning. This is why it's best to have TweenLite load last - it can check all the dependencies for you.
  4176. if ((a = window._gsQueue)) {
  4177. for (i = 0; i < a.length; i++) {
  4178. a[i]();
  4179. }
  4180. for (p in _classLookup) {
  4181. if (!_classLookup[p].def) {
  4182. console.log("Warning: TweenLite encountered missing dependency: com.greensock."+p);
  4183. }
  4184. }
  4185. }
  4186. })(window);