mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-14 21:43:18 +00:00
627 lines
71 KiB
HTML
627 lines
71 KiB
HTML
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
|
|
<html xmlns:yui="http://yuilibrary.com/rdf/1.0/yui.rdf#">
|
|
<head>
|
|
<meta http-equiv="content-type" content="text/html; charset=UTF-8" />
|
|
<title>API: animation Anim.js (YUI Library)</title>
|
|
|
|
<link rel="stylesheet" type="text/css" href="assets/reset-fonts-grids-min.css" />
|
|
<link rel="stylesheet" type="text/css" href="assets/api.css" />
|
|
|
|
<script type="text/javascript" src="assets/api-js"></script>
|
|
<script type="text/javascript" src="assets/ac-js"></script>
|
|
</head>
|
|
|
|
<body id="yahoo-com">
|
|
|
|
<div id="doc3" class="yui-t2">
|
|
<div id="hd">
|
|
<h1><a href="http://developer.yahoo.com/yui/" title="Yahoo! UI Library">Yahoo! UI Library</a></h1>
|
|
<h3>animation <span class="subtitle">2.8.2r1</span></h3>
|
|
<a href="./index.html" title="Yahoo! UI Library">Yahoo! UI Library</a>
|
|
> <a href="./module_animation.html" title="animation">animation</a>
|
|
|
|
> Anim.js (source view)
|
|
<form onsubmit="return false">
|
|
<div id="propertysearch">
|
|
Search: <input autocomplete="off" id="searchinput" />
|
|
<div id="searchresults">
|
|
|
|
</div>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
|
|
<div id="bd">
|
|
<div id="yui-main">
|
|
<div class="yui-b">
|
|
<form action="#" name="yui-classopts-form" method="get" id="yui-classopts-form">
|
|
<fieldset>
|
|
<legend>Filters</legend>
|
|
<span class="classopts"><input type="checkbox" name="show_private" id="show_private" /> <label for="show_private">Show Private</label></span>
|
|
<span class="classopts"><input type="checkbox" name="show_protected" id="show_protected" /> <label for="show_protected">Show Protected</label></span>
|
|
<span class="classopts"><input type="checkbox" name="show_deprecated" id="show_deprecated" /> <label for="show_deprecated">Show Deprecated</label></span>
|
|
</fieldset>
|
|
</form>
|
|
|
|
<div id="srcout">
|
|
<style>
|
|
#doc3 .classopts { display:none; }
|
|
</style>
|
|
<div class="highlight"><pre><span class="p">(</span><span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
|
|
|
|
<span class="kd">var</span> <span class="nx">Y</span> <span class="o">=</span> <span class="nx">YAHOO</span><span class="p">.</span><span class="nx">util</span><span class="p">;</span>
|
|
|
|
<span class="cm">/*</span>
|
|
<span class="cm">Copyright (c) 2006, Yahoo! Inc. All rights reserved.</span>
|
|
<span class="cm">Code licensed under the BSD License:</span>
|
|
<span class="cm">http://developer.yahoo.net/yui/license.txt</span>
|
|
<span class="cm">*/</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * The animation module provides allows effects to be added to HTMLElements.</span>
|
|
<span class="cm"> * @module animation</span>
|
|
<span class="cm"> * @requires yahoo, event, dom</span>
|
|
<span class="cm"> */</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> *</span>
|
|
<span class="cm"> * Base animation class that provides the interface for building animated effects.</span>
|
|
<span class="cm"> * <p>Usage: var myAnim = new YAHOO.util.Anim(el, { width: { from: 10, to: 100 } }, 1, YAHOO.util.Easing.easeOut);</p></span>
|
|
<span class="cm"> * @class Anim</span>
|
|
<span class="cm"> * @namespace YAHOO.util</span>
|
|
<span class="cm"> * @requires YAHOO.util.AnimMgr</span>
|
|
<span class="cm"> * @requires YAHOO.util.Easing</span>
|
|
<span class="cm"> * @requires YAHOO.util.Dom</span>
|
|
<span class="cm"> * @requires YAHOO.util.Event</span>
|
|
<span class="cm"> * @requires YAHOO.util.CustomEvent</span>
|
|
<span class="cm"> * @constructor</span>
|
|
<span class="cm"> * @param {String | HTMLElement} el Reference to the element that will be animated</span>
|
|
<span class="cm"> * @param {Object} attributes The attribute(s) to be animated. </span>
|
|
<span class="cm"> * Each attribute is an object with at minimum a "to" or "by" member defined. </span>
|
|
<span class="cm"> * Additional optional members are "from" (defaults to current value), "units" (defaults to "px"). </span>
|
|
<span class="cm"> * All attribute names use camelCase.</span>
|
|
<span class="cm"> * @param {Number} duration (optional, defaults to 1 second) Length of animation (frames or seconds), defaults to time-based</span>
|
|
<span class="cm"> * @param {Function} method (optional, defaults to YAHOO.util.Easing.easeNone) Computes the values that are applied to the attributes per frame (generally a YAHOO.util.Easing method)</span>
|
|
<span class="cm"> */</span>
|
|
|
|
<span class="kd">var</span> <span class="nx">Anim</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">el</span><span class="p">,</span> <span class="nx">attributes</span><span class="p">,</span> <span class="nx">duration</span><span class="p">,</span> <span class="nx">method</span><span class="p">)</span> <span class="p">{</span>
|
|
<span class="k">if</span> <span class="p">(</span><span class="o">!</span><span class="nx">el</span><span class="p">)</span> <span class="p">{</span>
|
|
<span class="nx">YAHOO</span><span class="p">.</span><span class="nx">log</span><span class="p">(</span><span class="s1">'element required to create Anim instance'</span><span class="p">,</span> <span class="s1">'error'</span><span class="p">,</span> <span class="s1">'Anim'</span><span class="p">);</span>
|
|
<span class="p">}</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">init</span><span class="p">(</span><span class="nx">el</span><span class="p">,</span> <span class="nx">attributes</span><span class="p">,</span> <span class="nx">duration</span><span class="p">,</span> <span class="nx">method</span><span class="p">);</span>
|
|
<span class="p">};</span>
|
|
|
|
<span class="nx">Anim</span><span class="p">.</span><span class="nx">NAME</span> <span class="o">=</span> <span class="s1">'Anim'</span><span class="p">;</span>
|
|
|
|
<span class="nx">Anim</span><span class="p">.</span><span class="nx">prototype</span> <span class="o">=</span> <span class="p">{</span>
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Provides a readable name for the Anim instance.</span>
|
|
<span class="cm"> * @method toString</span>
|
|
<span class="cm"> * @return {String}</span>
|
|
<span class="cm"> */</span>
|
|
<span class="nx">toString</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
|
|
<span class="kd">var</span> <span class="nx">el</span> <span class="o">=</span> <span class="k">this</span><span class="p">.</span><span class="nx">getEl</span><span class="p">()</span> <span class="o">||</span> <span class="p">{};</span>
|
|
<span class="kd">var</span> <span class="nx">id</span> <span class="o">=</span> <span class="nx">el</span><span class="p">.</span><span class="nx">id</span> <span class="o">||</span> <span class="nx">el</span><span class="p">.</span><span class="nx">tagName</span><span class="p">;</span>
|
|
<span class="k">return</span> <span class="p">(</span><span class="k">this</span><span class="p">.</span><span class="nx">constructor</span><span class="p">.</span><span class="nx">NAME</span> <span class="o">+</span> <span class="s1">': '</span> <span class="o">+</span> <span class="nx">id</span><span class="p">);</span>
|
|
<span class="p">},</span>
|
|
|
|
<span class="nx">patterns</span><span class="o">:</span> <span class="p">{</span> <span class="c1">// cached for performance</span>
|
|
<span class="nx">noNegatives</span><span class="o">:</span> <span class="sr">/width|height|opacity|padding/i</span><span class="p">,</span> <span class="c1">// keep at zero or above</span>
|
|
<span class="nx">offsetAttribute</span><span class="o">:</span> <span class="sr">/^((width|height)|(top|left))$/</span><span class="p">,</span> <span class="c1">// use offsetValue as default</span>
|
|
<span class="nx">defaultUnit</span><span class="o">:</span> <span class="sr">/width|height|top$|bottom$|left$|right$/i</span><span class="p">,</span> <span class="c1">// use 'px' by default</span>
|
|
<span class="nx">offsetUnit</span><span class="o">:</span> <span class="sr">/\d+(em|%|en|ex|pt|in|cm|mm|pc)$/i</span> <span class="c1">// IE may return these, so convert these to offset</span>
|
|
<span class="p">},</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Returns the value computed by the animation's "method".</span>
|
|
<span class="cm"> * @method doMethod</span>
|
|
<span class="cm"> * @param {String} attr The name of the attribute.</span>
|
|
<span class="cm"> * @param {Number} start The value this attribute should start from for this animation.</span>
|
|
<span class="cm"> * @param {Number} end The value this attribute should end at for this animation.</span>
|
|
<span class="cm"> * @return {Number} The Value to be applied to the attribute.</span>
|
|
<span class="cm"> */</span>
|
|
<span class="nx">doMethod</span><span class="o">:</span> <span class="kd">function</span><span class="p">(</span><span class="nx">attr</span><span class="p">,</span> <span class="nx">start</span><span class="p">,</span> <span class="nx">end</span><span class="p">)</span> <span class="p">{</span>
|
|
<span class="k">return</span> <span class="k">this</span><span class="p">.</span><span class="nx">method</span><span class="p">(</span><span class="k">this</span><span class="p">.</span><span class="nx">currentFrame</span><span class="p">,</span> <span class="nx">start</span><span class="p">,</span> <span class="nx">end</span> <span class="o">-</span> <span class="nx">start</span><span class="p">,</span> <span class="k">this</span><span class="p">.</span><span class="nx">totalFrames</span><span class="p">);</span>
|
|
<span class="p">},</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Applies a value to an attribute.</span>
|
|
<span class="cm"> * @method setAttribute</span>
|
|
<span class="cm"> * @param {String} attr The name of the attribute.</span>
|
|
<span class="cm"> * @param {Number} val The value to be applied to the attribute.</span>
|
|
<span class="cm"> * @param {String} unit The unit ('px', '%', etc.) of the value.</span>
|
|
<span class="cm"> */</span>
|
|
<span class="nx">setAttribute</span><span class="o">:</span> <span class="kd">function</span><span class="p">(</span><span class="nx">attr</span><span class="p">,</span> <span class="nx">val</span><span class="p">,</span> <span class="nx">unit</span><span class="p">)</span> <span class="p">{</span>
|
|
<span class="kd">var</span> <span class="nx">el</span> <span class="o">=</span> <span class="k">this</span><span class="p">.</span><span class="nx">getEl</span><span class="p">();</span>
|
|
<span class="k">if</span> <span class="p">(</span> <span class="k">this</span><span class="p">.</span><span class="nx">patterns</span><span class="p">.</span><span class="nx">noNegatives</span><span class="p">.</span><span class="nx">test</span><span class="p">(</span><span class="nx">attr</span><span class="p">)</span> <span class="p">)</span> <span class="p">{</span>
|
|
<span class="nx">val</span> <span class="o">=</span> <span class="p">(</span><span class="nx">val</span> <span class="o">></span> <span class="mi">0</span><span class="p">)</span> <span class="o">?</span> <span class="nx">val</span> <span class="o">:</span> <span class="mi">0</span><span class="p">;</span>
|
|
<span class="p">}</span>
|
|
|
|
<span class="k">if</span> <span class="p">(</span><span class="nx">attr</span> <span class="k">in</span> <span class="nx">el</span> <span class="o">&&</span> <span class="o">!</span><span class="p">(</span><span class="s1">'style'</span> <span class="k">in</span> <span class="nx">el</span> <span class="o">&&</span> <span class="nx">attr</span> <span class="k">in</span> <span class="nx">el</span><span class="p">.</span><span class="nx">style</span><span class="p">))</span> <span class="p">{</span>
|
|
<span class="nx">el</span><span class="p">[</span><span class="nx">attr</span><span class="p">]</span> <span class="o">=</span> <span class="nx">val</span><span class="p">;</span>
|
|
<span class="p">}</span> <span class="k">else</span> <span class="p">{</span>
|
|
<span class="nx">Y</span><span class="p">.</span><span class="nx">Dom</span><span class="p">.</span><span class="nx">setStyle</span><span class="p">(</span><span class="nx">el</span><span class="p">,</span> <span class="nx">attr</span><span class="p">,</span> <span class="nx">val</span> <span class="o">+</span> <span class="nx">unit</span><span class="p">);</span>
|
|
<span class="p">}</span>
|
|
<span class="p">},</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Returns current value of the attribute.</span>
|
|
<span class="cm"> * @method getAttribute</span>
|
|
<span class="cm"> * @param {String} attr The name of the attribute.</span>
|
|
<span class="cm"> * @return {Number} val The current value of the attribute.</span>
|
|
<span class="cm"> */</span>
|
|
<span class="nx">getAttribute</span><span class="o">:</span> <span class="kd">function</span><span class="p">(</span><span class="nx">attr</span><span class="p">)</span> <span class="p">{</span>
|
|
<span class="kd">var</span> <span class="nx">el</span> <span class="o">=</span> <span class="k">this</span><span class="p">.</span><span class="nx">getEl</span><span class="p">();</span>
|
|
<span class="kd">var</span> <span class="nx">val</span> <span class="o">=</span> <span class="nx">Y</span><span class="p">.</span><span class="nx">Dom</span><span class="p">.</span><span class="nx">getStyle</span><span class="p">(</span><span class="nx">el</span><span class="p">,</span> <span class="nx">attr</span><span class="p">);</span>
|
|
|
|
<span class="k">if</span> <span class="p">(</span><span class="nx">val</span> <span class="o">!==</span> <span class="s1">'auto'</span> <span class="o">&&</span> <span class="o">!</span><span class="k">this</span><span class="p">.</span><span class="nx">patterns</span><span class="p">.</span><span class="nx">offsetUnit</span><span class="p">.</span><span class="nx">test</span><span class="p">(</span><span class="nx">val</span><span class="p">))</span> <span class="p">{</span>
|
|
<span class="k">return</span> <span class="nb">parseFloat</span><span class="p">(</span><span class="nx">val</span><span class="p">);</span>
|
|
<span class="p">}</span>
|
|
|
|
<span class="kd">var</span> <span class="nx">a</span> <span class="o">=</span> <span class="k">this</span><span class="p">.</span><span class="nx">patterns</span><span class="p">.</span><span class="nx">offsetAttribute</span><span class="p">.</span><span class="nx">exec</span><span class="p">(</span><span class="nx">attr</span><span class="p">)</span> <span class="o">||</span> <span class="p">[];</span>
|
|
<span class="kd">var</span> <span class="nx">pos</span> <span class="o">=</span> <span class="o">!!</span><span class="p">(</span> <span class="nx">a</span><span class="p">[</span><span class="mi">3</span><span class="p">]</span> <span class="p">);</span> <span class="c1">// top or left</span>
|
|
<span class="kd">var</span> <span class="nx">box</span> <span class="o">=</span> <span class="o">!!</span><span class="p">(</span> <span class="nx">a</span><span class="p">[</span><span class="mi">2</span><span class="p">]</span> <span class="p">);</span> <span class="c1">// width or height</span>
|
|
|
|
<span class="k">if</span> <span class="p">(</span><span class="s1">'style'</span> <span class="k">in</span> <span class="nx">el</span><span class="p">)</span> <span class="p">{</span>
|
|
<span class="c1">// use offsets for width/height and abs pos top/left</span>
|
|
<span class="k">if</span> <span class="p">(</span> <span class="nx">box</span> <span class="o">||</span> <span class="p">(</span><span class="nx">Y</span><span class="p">.</span><span class="nx">Dom</span><span class="p">.</span><span class="nx">getStyle</span><span class="p">(</span><span class="nx">el</span><span class="p">,</span> <span class="s1">'position'</span><span class="p">)</span> <span class="o">==</span> <span class="s1">'absolute'</span> <span class="o">&&</span> <span class="nx">pos</span><span class="p">)</span> <span class="p">)</span> <span class="p">{</span>
|
|
<span class="nx">val</span> <span class="o">=</span> <span class="nx">el</span><span class="p">[</span><span class="s1">'offset'</span> <span class="o">+</span> <span class="nx">a</span><span class="p">[</span><span class="mi">0</span><span class="p">].</span><span class="nx">charAt</span><span class="p">(</span><span class="mi">0</span><span class="p">).</span><span class="nx">toUpperCase</span><span class="p">()</span> <span class="o">+</span> <span class="nx">a</span><span class="p">[</span><span class="mi">0</span><span class="p">].</span><span class="nx">substr</span><span class="p">(</span><span class="mi">1</span><span class="p">)];</span>
|
|
<span class="p">}</span> <span class="k">else</span> <span class="p">{</span> <span class="c1">// default to zero for other 'auto'</span>
|
|
<span class="nx">val</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span>
|
|
<span class="p">}</span>
|
|
<span class="p">}</span> <span class="k">else</span> <span class="k">if</span> <span class="p">(</span><span class="nx">attr</span> <span class="k">in</span> <span class="nx">el</span><span class="p">)</span> <span class="p">{</span>
|
|
<span class="nx">val</span> <span class="o">=</span> <span class="nx">el</span><span class="p">[</span><span class="nx">attr</span><span class="p">];</span>
|
|
<span class="p">}</span>
|
|
|
|
<span class="k">return</span> <span class="nx">val</span><span class="p">;</span>
|
|
<span class="p">},</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Returns the unit to use when none is supplied.</span>
|
|
<span class="cm"> * @method getDefaultUnit</span>
|
|
<span class="cm"> * @param {attr} attr The name of the attribute.</span>
|
|
<span class="cm"> * @return {String} The default unit to be used.</span>
|
|
<span class="cm"> */</span>
|
|
<span class="nx">getDefaultUnit</span><span class="o">:</span> <span class="kd">function</span><span class="p">(</span><span class="nx">attr</span><span class="p">)</span> <span class="p">{</span>
|
|
<span class="k">if</span> <span class="p">(</span> <span class="k">this</span><span class="p">.</span><span class="nx">patterns</span><span class="p">.</span><span class="nx">defaultUnit</span><span class="p">.</span><span class="nx">test</span><span class="p">(</span><span class="nx">attr</span><span class="p">)</span> <span class="p">)</span> <span class="p">{</span>
|
|
<span class="k">return</span> <span class="s1">'px'</span><span class="p">;</span>
|
|
<span class="p">}</span>
|
|
|
|
<span class="k">return</span> <span class="s1">''</span><span class="p">;</span>
|
|
<span class="p">},</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Sets the actual values to be used during the animation. Should only be needed for subclass use.</span>
|
|
<span class="cm"> * @method setRuntimeAttribute</span>
|
|
<span class="cm"> * @param {Object} attr The attribute object</span>
|
|
<span class="cm"> * @private </span>
|
|
<span class="cm"> */</span>
|
|
<span class="nx">setRuntimeAttribute</span><span class="o">:</span> <span class="kd">function</span><span class="p">(</span><span class="nx">attr</span><span class="p">)</span> <span class="p">{</span>
|
|
<span class="kd">var</span> <span class="nx">start</span><span class="p">;</span>
|
|
<span class="kd">var</span> <span class="nx">end</span><span class="p">;</span>
|
|
<span class="kd">var</span> <span class="nx">attributes</span> <span class="o">=</span> <span class="k">this</span><span class="p">.</span><span class="nx">attributes</span><span class="p">;</span>
|
|
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">runtimeAttributes</span><span class="p">[</span><span class="nx">attr</span><span class="p">]</span> <span class="o">=</span> <span class="p">{};</span>
|
|
|
|
<span class="kd">var</span> <span class="nx">isset</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">prop</span><span class="p">)</span> <span class="p">{</span>
|
|
<span class="k">return</span> <span class="p">(</span><span class="k">typeof</span> <span class="nx">prop</span> <span class="o">!==</span> <span class="s1">'undefined'</span><span class="p">);</span>
|
|
<span class="p">};</span>
|
|
|
|
<span class="k">if</span> <span class="p">(</span> <span class="o">!</span><span class="nx">isset</span><span class="p">(</span><span class="nx">attributes</span><span class="p">[</span><span class="nx">attr</span><span class="p">][</span><span class="s1">'to'</span><span class="p">])</span> <span class="o">&&</span> <span class="o">!</span><span class="nx">isset</span><span class="p">(</span><span class="nx">attributes</span><span class="p">[</span><span class="nx">attr</span><span class="p">][</span><span class="s1">'by'</span><span class="p">])</span> <span class="p">)</span> <span class="p">{</span>
|
|
<span class="k">return</span> <span class="kc">false</span><span class="p">;</span> <span class="c1">// note return; nothing to animate to</span>
|
|
<span class="p">}</span>
|
|
|
|
<span class="nx">start</span> <span class="o">=</span> <span class="p">(</span> <span class="nx">isset</span><span class="p">(</span><span class="nx">attributes</span><span class="p">[</span><span class="nx">attr</span><span class="p">][</span><span class="s1">'from'</span><span class="p">])</span> <span class="p">)</span> <span class="o">?</span> <span class="nx">attributes</span><span class="p">[</span><span class="nx">attr</span><span class="p">][</span><span class="s1">'from'</span><span class="p">]</span> <span class="o">:</span> <span class="k">this</span><span class="p">.</span><span class="nx">getAttribute</span><span class="p">(</span><span class="nx">attr</span><span class="p">);</span>
|
|
|
|
<span class="c1">// To beats by, per SMIL 2.1 spec</span>
|
|
<span class="k">if</span> <span class="p">(</span> <span class="nx">isset</span><span class="p">(</span><span class="nx">attributes</span><span class="p">[</span><span class="nx">attr</span><span class="p">][</span><span class="s1">'to'</span><span class="p">])</span> <span class="p">)</span> <span class="p">{</span>
|
|
<span class="nx">end</span> <span class="o">=</span> <span class="nx">attributes</span><span class="p">[</span><span class="nx">attr</span><span class="p">][</span><span class="s1">'to'</span><span class="p">];</span>
|
|
<span class="p">}</span> <span class="k">else</span> <span class="k">if</span> <span class="p">(</span> <span class="nx">isset</span><span class="p">(</span><span class="nx">attributes</span><span class="p">[</span><span class="nx">attr</span><span class="p">][</span><span class="s1">'by'</span><span class="p">])</span> <span class="p">)</span> <span class="p">{</span>
|
|
<span class="k">if</span> <span class="p">(</span><span class="nx">start</span><span class="p">.</span><span class="nx">constructor</span> <span class="o">==</span> <span class="nb">Array</span><span class="p">)</span> <span class="p">{</span>
|
|
<span class="nx">end</span> <span class="o">=</span> <span class="p">[];</span>
|
|
<span class="k">for</span> <span class="p">(</span><span class="kd">var</span> <span class="nx">i</span> <span class="o">=</span> <span class="mi">0</span><span class="p">,</span> <span class="nx">len</span> <span class="o">=</span> <span class="nx">start</span><span class="p">.</span><span class="nx">length</span><span class="p">;</span> <span class="nx">i</span> <span class="o"><</span> <span class="nx">len</span><span class="p">;</span> <span class="o">++</span><span class="nx">i</span><span class="p">)</span> <span class="p">{</span>
|
|
<span class="nx">end</span><span class="p">[</span><span class="nx">i</span><span class="p">]</span> <span class="o">=</span> <span class="nx">start</span><span class="p">[</span><span class="nx">i</span><span class="p">]</span> <span class="o">+</span> <span class="nx">attributes</span><span class="p">[</span><span class="nx">attr</span><span class="p">][</span><span class="s1">'by'</span><span class="p">][</span><span class="nx">i</span><span class="p">]</span> <span class="o">*</span> <span class="mi">1</span><span class="p">;</span> <span class="c1">// times 1 to cast "by" </span>
|
|
<span class="p">}</span>
|
|
<span class="p">}</span> <span class="k">else</span> <span class="p">{</span>
|
|
<span class="nx">end</span> <span class="o">=</span> <span class="nx">start</span> <span class="o">+</span> <span class="nx">attributes</span><span class="p">[</span><span class="nx">attr</span><span class="p">][</span><span class="s1">'by'</span><span class="p">]</span> <span class="o">*</span> <span class="mi">1</span><span class="p">;</span>
|
|
<span class="p">}</span>
|
|
<span class="p">}</span>
|
|
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">runtimeAttributes</span><span class="p">[</span><span class="nx">attr</span><span class="p">].</span><span class="nx">start</span> <span class="o">=</span> <span class="nx">start</span><span class="p">;</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">runtimeAttributes</span><span class="p">[</span><span class="nx">attr</span><span class="p">].</span><span class="nx">end</span> <span class="o">=</span> <span class="nx">end</span><span class="p">;</span>
|
|
|
|
<span class="c1">// set units if needed</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">runtimeAttributes</span><span class="p">[</span><span class="nx">attr</span><span class="p">].</span><span class="nx">unit</span> <span class="o">=</span> <span class="p">(</span> <span class="nx">isset</span><span class="p">(</span><span class="nx">attributes</span><span class="p">[</span><span class="nx">attr</span><span class="p">].</span><span class="nx">unit</span><span class="p">)</span> <span class="p">)</span> <span class="o">?</span>
|
|
<span class="nx">attributes</span><span class="p">[</span><span class="nx">attr</span><span class="p">][</span><span class="s1">'unit'</span><span class="p">]</span> <span class="o">:</span> <span class="k">this</span><span class="p">.</span><span class="nx">getDefaultUnit</span><span class="p">(</span><span class="nx">attr</span><span class="p">);</span>
|
|
<span class="k">return</span> <span class="kc">true</span><span class="p">;</span>
|
|
<span class="p">},</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Constructor for Anim instance.</span>
|
|
<span class="cm"> * @method init</span>
|
|
<span class="cm"> * @param {String | HTMLElement} el Reference to the element that will be animated</span>
|
|
<span class="cm"> * @param {Object} attributes The attribute(s) to be animated. </span>
|
|
<span class="cm"> * Each attribute is an object with at minimum a "to" or "by" member defined. </span>
|
|
<span class="cm"> * Additional optional members are "from" (defaults to current value), "units" (defaults to "px"). </span>
|
|
<span class="cm"> * All attribute names use camelCase.</span>
|
|
<span class="cm"> * @param {Number} duration (optional, defaults to 1 second) Length of animation (frames or seconds), defaults to time-based</span>
|
|
<span class="cm"> * @param {Function} method (optional, defaults to YAHOO.util.Easing.easeNone) Computes the values that are applied to the attributes per frame (generally a YAHOO.util.Easing method)</span>
|
|
<span class="cm"> */</span>
|
|
<span class="nx">init</span><span class="o">:</span> <span class="kd">function</span><span class="p">(</span><span class="nx">el</span><span class="p">,</span> <span class="nx">attributes</span><span class="p">,</span> <span class="nx">duration</span><span class="p">,</span> <span class="nx">method</span><span class="p">)</span> <span class="p">{</span>
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Whether or not the animation is running.</span>
|
|
<span class="cm"> * @property isAnimated</span>
|
|
<span class="cm"> * @private</span>
|
|
<span class="cm"> * @type Boolean</span>
|
|
<span class="cm"> */</span>
|
|
<span class="kd">var</span> <span class="nx">isAnimated</span> <span class="o">=</span> <span class="kc">false</span><span class="p">;</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * A Date object that is created when the animation begins.</span>
|
|
<span class="cm"> * @property startTime</span>
|
|
<span class="cm"> * @private</span>
|
|
<span class="cm"> * @type Date</span>
|
|
<span class="cm"> */</span>
|
|
<span class="kd">var</span> <span class="nx">startTime</span> <span class="o">=</span> <span class="kc">null</span><span class="p">;</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * The number of frames this animation was able to execute.</span>
|
|
<span class="cm"> * @property actualFrames</span>
|
|
<span class="cm"> * @private</span>
|
|
<span class="cm"> * @type Int</span>
|
|
<span class="cm"> */</span>
|
|
<span class="kd">var</span> <span class="nx">actualFrames</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * The element to be animated.</span>
|
|
<span class="cm"> * @property el</span>
|
|
<span class="cm"> * @private</span>
|
|
<span class="cm"> * @type HTMLElement</span>
|
|
<span class="cm"> */</span>
|
|
<span class="nx">el</span> <span class="o">=</span> <span class="nx">Y</span><span class="p">.</span><span class="nx">Dom</span><span class="p">.</span><span class="nx">get</span><span class="p">(</span><span class="nx">el</span><span class="p">);</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * The collection of attributes to be animated. </span>
|
|
<span class="cm"> * Each attribute must have at least a "to" or "by" defined in order to animate. </span>
|
|
<span class="cm"> * If "to" is supplied, the animation will end with the attribute at that value. </span>
|
|
<span class="cm"> * If "by" is supplied, the animation will end at that value plus its starting value. </span>
|
|
<span class="cm"> * If both are supplied, "to" is used, and "by" is ignored. </span>
|
|
<span class="cm"> * Optional additional member include "from" (the value the attribute should start animating from, defaults to current value), and "unit" (the units to apply to the values).</span>
|
|
<span class="cm"> * @property attributes</span>
|
|
<span class="cm"> * @type Object</span>
|
|
<span class="cm"> */</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">attributes</span> <span class="o">=</span> <span class="nx">attributes</span> <span class="o">||</span> <span class="p">{};</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * The length of the animation. Defaults to "1" (second).</span>
|
|
<span class="cm"> * @property duration</span>
|
|
<span class="cm"> * @type Number</span>
|
|
<span class="cm"> */</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">duration</span> <span class="o">=</span> <span class="o">!</span><span class="nx">YAHOO</span><span class="p">.</span><span class="nx">lang</span><span class="p">.</span><span class="nx">isUndefined</span><span class="p">(</span><span class="nx">duration</span><span class="p">)</span> <span class="o">?</span> <span class="nx">duration</span> <span class="o">:</span> <span class="mi">1</span><span class="p">;</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * The method that will provide values to the attribute(s) during the animation. </span>
|
|
<span class="cm"> * Defaults to "YAHOO.util.Easing.easeNone".</span>
|
|
<span class="cm"> * @property method</span>
|
|
<span class="cm"> * @type Function</span>
|
|
<span class="cm"> */</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">method</span> <span class="o">=</span> <span class="nx">method</span> <span class="o">||</span> <span class="nx">Y</span><span class="p">.</span><span class="nx">Easing</span><span class="p">.</span><span class="nx">easeNone</span><span class="p">;</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Whether or not the duration should be treated as seconds.</span>
|
|
<span class="cm"> * Defaults to true.</span>
|
|
<span class="cm"> * @property useSeconds</span>
|
|
<span class="cm"> * @type Boolean</span>
|
|
<span class="cm"> */</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">useSeconds</span> <span class="o">=</span> <span class="kc">true</span><span class="p">;</span> <span class="c1">// default to seconds</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * The location of the current animation on the timeline.</span>
|
|
<span class="cm"> * In time-based animations, this is used by AnimMgr to ensure the animation finishes on time.</span>
|
|
<span class="cm"> * @property currentFrame</span>
|
|
<span class="cm"> * @type Int</span>
|
|
<span class="cm"> */</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">currentFrame</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * The total number of frames to be executed.</span>
|
|
<span class="cm"> * In time-based animations, this is used by AnimMgr to ensure the animation finishes on time.</span>
|
|
<span class="cm"> * @property totalFrames</span>
|
|
<span class="cm"> * @type Int</span>
|
|
<span class="cm"> */</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">totalFrames</span> <span class="o">=</span> <span class="nx">Y</span><span class="p">.</span><span class="nx">AnimMgr</span><span class="p">.</span><span class="nx">fps</span><span class="p">;</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Changes the animated element</span>
|
|
<span class="cm"> * @method setEl</span>
|
|
<span class="cm"> */</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">setEl</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">element</span><span class="p">)</span> <span class="p">{</span>
|
|
<span class="nx">el</span> <span class="o">=</span> <span class="nx">Y</span><span class="p">.</span><span class="nx">Dom</span><span class="p">.</span><span class="nx">get</span><span class="p">(</span><span class="nx">element</span><span class="p">);</span>
|
|
<span class="p">};</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Returns a reference to the animated element.</span>
|
|
<span class="cm"> * @method getEl</span>
|
|
<span class="cm"> * @return {HTMLElement}</span>
|
|
<span class="cm"> */</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">getEl</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nx">el</span><span class="p">;</span> <span class="p">};</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Checks whether the element is currently animated.</span>
|
|
<span class="cm"> * @method isAnimated</span>
|
|
<span class="cm"> * @return {Boolean} current value of isAnimated. </span>
|
|
<span class="cm"> */</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">isAnimated</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
|
|
<span class="k">return</span> <span class="nx">isAnimated</span><span class="p">;</span>
|
|
<span class="p">};</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Returns the animation start time.</span>
|
|
<span class="cm"> * @method getStartTime</span>
|
|
<span class="cm"> * @return {Date} current value of startTime. </span>
|
|
<span class="cm"> */</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">getStartTime</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
|
|
<span class="k">return</span> <span class="nx">startTime</span><span class="p">;</span>
|
|
<span class="p">};</span>
|
|
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">runtimeAttributes</span> <span class="o">=</span> <span class="p">{};</span>
|
|
|
|
<span class="kd">var</span> <span class="nx">logger</span> <span class="o">=</span> <span class="p">{};</span>
|
|
<span class="nx">logger</span><span class="p">.</span><span class="nx">log</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span><span class="nx">YAHOO</span><span class="p">.</span><span class="nx">log</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">window</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">)};</span>
|
|
|
|
<span class="nx">logger</span><span class="p">.</span><span class="nx">log</span><span class="p">(</span><span class="s1">'creating new instance of '</span> <span class="o">+</span> <span class="k">this</span><span class="p">);</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Starts the animation by registering it with the animation manager. </span>
|
|
<span class="cm"> * @method animate </span>
|
|
<span class="cm"> */</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">animate</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
|
|
<span class="k">if</span> <span class="p">(</span> <span class="k">this</span><span class="p">.</span><span class="nx">isAnimated</span><span class="p">()</span> <span class="p">)</span> <span class="p">{</span>
|
|
<span class="k">return</span> <span class="kc">false</span><span class="p">;</span>
|
|
<span class="p">}</span>
|
|
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">currentFrame</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span>
|
|
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">totalFrames</span> <span class="o">=</span> <span class="p">(</span> <span class="k">this</span><span class="p">.</span><span class="nx">useSeconds</span> <span class="p">)</span> <span class="o">?</span> <span class="nb">Math</span><span class="p">.</span><span class="nx">ceil</span><span class="p">(</span><span class="nx">Y</span><span class="p">.</span><span class="nx">AnimMgr</span><span class="p">.</span><span class="nx">fps</span> <span class="o">*</span> <span class="k">this</span><span class="p">.</span><span class="nx">duration</span><span class="p">)</span> <span class="o">:</span> <span class="k">this</span><span class="p">.</span><span class="nx">duration</span><span class="p">;</span>
|
|
|
|
<span class="k">if</span> <span class="p">(</span><span class="k">this</span><span class="p">.</span><span class="nx">duration</span> <span class="o">===</span> <span class="mi">0</span> <span class="o">&&</span> <span class="k">this</span><span class="p">.</span><span class="nx">useSeconds</span><span class="p">)</span> <span class="p">{</span> <span class="c1">// jump to last frame if zero second duration </span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">totalFrames</span> <span class="o">=</span> <span class="mi">1</span><span class="p">;</span>
|
|
<span class="p">}</span>
|
|
<span class="nx">Y</span><span class="p">.</span><span class="nx">AnimMgr</span><span class="p">.</span><span class="nx">registerElement</span><span class="p">(</span><span class="k">this</span><span class="p">);</span>
|
|
<span class="k">return</span> <span class="kc">true</span><span class="p">;</span>
|
|
<span class="p">};</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Stops the animation. Normally called by AnimMgr when animation completes.</span>
|
|
<span class="cm"> * @method stop</span>
|
|
<span class="cm"> * @param {Boolean} finish (optional) If true, animation will jump to final frame.</span>
|
|
<span class="cm"> */</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">stop</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">finish</span><span class="p">)</span> <span class="p">{</span>
|
|
<span class="k">if</span> <span class="p">(</span><span class="o">!</span><span class="k">this</span><span class="p">.</span><span class="nx">isAnimated</span><span class="p">())</span> <span class="p">{</span> <span class="c1">// nothing to stop</span>
|
|
<span class="k">return</span> <span class="kc">false</span><span class="p">;</span>
|
|
<span class="p">}</span>
|
|
|
|
<span class="k">if</span> <span class="p">(</span><span class="nx">finish</span><span class="p">)</span> <span class="p">{</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">currentFrame</span> <span class="o">=</span> <span class="k">this</span><span class="p">.</span><span class="nx">totalFrames</span><span class="p">;</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">_onTween</span><span class="p">.</span><span class="nx">fire</span><span class="p">();</span>
|
|
<span class="p">}</span>
|
|
<span class="nx">Y</span><span class="p">.</span><span class="nx">AnimMgr</span><span class="p">.</span><span class="nx">stop</span><span class="p">(</span><span class="k">this</span><span class="p">);</span>
|
|
<span class="p">};</span>
|
|
|
|
<span class="kd">var</span> <span class="nx">onStart</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">onStart</span><span class="p">.</span><span class="nx">fire</span><span class="p">();</span>
|
|
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">runtimeAttributes</span> <span class="o">=</span> <span class="p">{};</span>
|
|
<span class="k">for</span> <span class="p">(</span><span class="kd">var</span> <span class="nx">attr</span> <span class="k">in</span> <span class="k">this</span><span class="p">.</span><span class="nx">attributes</span><span class="p">)</span> <span class="p">{</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">setRuntimeAttribute</span><span class="p">(</span><span class="nx">attr</span><span class="p">);</span>
|
|
<span class="p">}</span>
|
|
|
|
<span class="nx">isAnimated</span> <span class="o">=</span> <span class="kc">true</span><span class="p">;</span>
|
|
<span class="nx">actualFrames</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span>
|
|
<span class="nx">startTime</span> <span class="o">=</span> <span class="k">new</span> <span class="nb">Date</span><span class="p">();</span>
|
|
<span class="p">};</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Feeds the starting and ending values for each animated attribute to doMethod once per frame, then applies the resulting value to the attribute(s).</span>
|
|
<span class="cm"> * @private</span>
|
|
<span class="cm"> */</span>
|
|
|
|
<span class="kd">var</span> <span class="nx">onTween</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
|
|
<span class="kd">var</span> <span class="nx">data</span> <span class="o">=</span> <span class="p">{</span>
|
|
<span class="nx">duration</span><span class="o">:</span> <span class="k">new</span> <span class="nb">Date</span><span class="p">()</span> <span class="o">-</span> <span class="k">this</span><span class="p">.</span><span class="nx">getStartTime</span><span class="p">(),</span>
|
|
<span class="nx">currentFrame</span><span class="o">:</span> <span class="k">this</span><span class="p">.</span><span class="nx">currentFrame</span>
|
|
<span class="p">};</span>
|
|
|
|
<span class="nx">data</span><span class="p">.</span><span class="nx">toString</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
|
|
<span class="k">return</span> <span class="p">(</span>
|
|
<span class="s1">'duration: '</span> <span class="o">+</span> <span class="nx">data</span><span class="p">.</span><span class="nx">duration</span> <span class="o">+</span>
|
|
<span class="s1">', currentFrame: '</span> <span class="o">+</span> <span class="nx">data</span><span class="p">.</span><span class="nx">currentFrame</span>
|
|
<span class="p">);</span>
|
|
<span class="p">};</span>
|
|
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">onTween</span><span class="p">.</span><span class="nx">fire</span><span class="p">(</span><span class="nx">data</span><span class="p">);</span>
|
|
|
|
<span class="kd">var</span> <span class="nx">runtimeAttributes</span> <span class="o">=</span> <span class="k">this</span><span class="p">.</span><span class="nx">runtimeAttributes</span><span class="p">;</span>
|
|
|
|
<span class="k">for</span> <span class="p">(</span><span class="kd">var</span> <span class="nx">attr</span> <span class="k">in</span> <span class="nx">runtimeAttributes</span><span class="p">)</span> <span class="p">{</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">setAttribute</span><span class="p">(</span><span class="nx">attr</span><span class="p">,</span> <span class="k">this</span><span class="p">.</span><span class="nx">doMethod</span><span class="p">(</span><span class="nx">attr</span><span class="p">,</span> <span class="nx">runtimeAttributes</span><span class="p">[</span><span class="nx">attr</span><span class="p">].</span><span class="nx">start</span><span class="p">,</span> <span class="nx">runtimeAttributes</span><span class="p">[</span><span class="nx">attr</span><span class="p">].</span><span class="nx">end</span><span class="p">),</span> <span class="nx">runtimeAttributes</span><span class="p">[</span><span class="nx">attr</span><span class="p">].</span><span class="nx">unit</span><span class="p">);</span>
|
|
<span class="p">}</span>
|
|
|
|
<span class="nx">actualFrames</span> <span class="o">+=</span> <span class="mi">1</span><span class="p">;</span>
|
|
<span class="p">};</span>
|
|
|
|
<span class="kd">var</span> <span class="nx">onComplete</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
|
|
<span class="kd">var</span> <span class="nx">actual_duration</span> <span class="o">=</span> <span class="p">(</span><span class="k">new</span> <span class="nb">Date</span><span class="p">()</span> <span class="o">-</span> <span class="nx">startTime</span><span class="p">)</span> <span class="o">/</span> <span class="mi">1000</span> <span class="p">;</span>
|
|
|
|
<span class="kd">var</span> <span class="nx">data</span> <span class="o">=</span> <span class="p">{</span>
|
|
<span class="nx">duration</span><span class="o">:</span> <span class="nx">actual_duration</span><span class="p">,</span>
|
|
<span class="nx">frames</span><span class="o">:</span> <span class="nx">actualFrames</span><span class="p">,</span>
|
|
<span class="nx">fps</span><span class="o">:</span> <span class="nx">actualFrames</span> <span class="o">/</span> <span class="nx">actual_duration</span>
|
|
<span class="p">};</span>
|
|
|
|
<span class="nx">data</span><span class="p">.</span><span class="nx">toString</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
|
|
<span class="k">return</span> <span class="p">(</span>
|
|
<span class="s1">'duration: '</span> <span class="o">+</span> <span class="nx">data</span><span class="p">.</span><span class="nx">duration</span> <span class="o">+</span>
|
|
<span class="s1">', frames: '</span> <span class="o">+</span> <span class="nx">data</span><span class="p">.</span><span class="nx">frames</span> <span class="o">+</span>
|
|
<span class="s1">', fps: '</span> <span class="o">+</span> <span class="nx">data</span><span class="p">.</span><span class="nx">fps</span>
|
|
<span class="p">);</span>
|
|
<span class="p">};</span>
|
|
|
|
<span class="nx">isAnimated</span> <span class="o">=</span> <span class="kc">false</span><span class="p">;</span>
|
|
<span class="nx">actualFrames</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">onComplete</span><span class="p">.</span><span class="nx">fire</span><span class="p">(</span><span class="nx">data</span><span class="p">);</span>
|
|
<span class="p">};</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Custom event that fires after onStart, useful in subclassing</span>
|
|
<span class="cm"> * @private</span>
|
|
<span class="cm"> */</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">_onStart</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">Y</span><span class="p">.</span><span class="nx">CustomEvent</span><span class="p">(</span><span class="s1">'_start'</span><span class="p">,</span> <span class="k">this</span><span class="p">,</span> <span class="kc">true</span><span class="p">);</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Custom event that fires when animation begins</span>
|
|
<span class="cm"> * Listen via subscribe method (e.g. myAnim.onStart.subscribe(someFunction)</span>
|
|
<span class="cm"> * @event onStart</span>
|
|
<span class="cm"> */</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">onStart</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">Y</span><span class="p">.</span><span class="nx">CustomEvent</span><span class="p">(</span><span class="s1">'start'</span><span class="p">,</span> <span class="k">this</span><span class="p">);</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Custom event that fires between each frame</span>
|
|
<span class="cm"> * Listen via subscribe method (e.g. myAnim.onTween.subscribe(someFunction)</span>
|
|
<span class="cm"> * @event onTween</span>
|
|
<span class="cm"> */</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">onTween</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">Y</span><span class="p">.</span><span class="nx">CustomEvent</span><span class="p">(</span><span class="s1">'tween'</span><span class="p">,</span> <span class="k">this</span><span class="p">);</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Custom event that fires after onTween</span>
|
|
<span class="cm"> * @private</span>
|
|
<span class="cm"> */</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">_onTween</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">Y</span><span class="p">.</span><span class="nx">CustomEvent</span><span class="p">(</span><span class="s1">'_tween'</span><span class="p">,</span> <span class="k">this</span><span class="p">,</span> <span class="kc">true</span><span class="p">);</span>
|
|
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Custom event that fires when animation ends</span>
|
|
<span class="cm"> * Listen via subscribe method (e.g. myAnim.onComplete.subscribe(someFunction)</span>
|
|
<span class="cm"> * @event onComplete</span>
|
|
<span class="cm"> */</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">onComplete</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">Y</span><span class="p">.</span><span class="nx">CustomEvent</span><span class="p">(</span><span class="s1">'complete'</span><span class="p">,</span> <span class="k">this</span><span class="p">);</span>
|
|
<span class="cm">/**</span>
|
|
<span class="cm"> * Custom event that fires after onComplete</span>
|
|
<span class="cm"> * @private</span>
|
|
<span class="cm"> */</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">_onComplete</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">Y</span><span class="p">.</span><span class="nx">CustomEvent</span><span class="p">(</span><span class="s1">'_complete'</span><span class="p">,</span> <span class="k">this</span><span class="p">,</span> <span class="kc">true</span><span class="p">);</span>
|
|
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">_onStart</span><span class="p">.</span><span class="nx">subscribe</span><span class="p">(</span><span class="nx">onStart</span><span class="p">);</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">_onTween</span><span class="p">.</span><span class="nx">subscribe</span><span class="p">(</span><span class="nx">onTween</span><span class="p">);</span>
|
|
<span class="k">this</span><span class="p">.</span><span class="nx">_onComplete</span><span class="p">.</span><span class="nx">subscribe</span><span class="p">(</span><span class="nx">onComplete</span><span class="p">);</span>
|
|
<span class="p">}</span>
|
|
<span class="p">};</span>
|
|
|
|
<span class="nx">Y</span><span class="p">.</span><span class="nx">Anim</span> <span class="o">=</span> <span class="nx">Anim</span><span class="p">;</span>
|
|
<span class="p">})();</span>
|
|
</pre></div>
|
|
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="yui-b">
|
|
<div class="nav">
|
|
|
|
<div id="moduleList" class="module">
|
|
<h4>Modules</h4>
|
|
<ul class="content">
|
|
<li class="selected"><a href="module_animation.html" title="animation">animation</a></li>
|
|
<li class=""><a href="module_autocomplete.html" title="autocomplete">autocomplete</a></li>
|
|
<li class=""><a href="module_button.html" title="button">button</a></li>
|
|
<li class=""><a href="module_calendar.html" title="calendar">calendar</a></li>
|
|
<li class=""><a href="module_carousel.html" title="carousel">carousel</a></li>
|
|
<li class=""><a href="module_charts.html" title="charts">charts</a></li>
|
|
<li class=""><a href="module_colorpicker.html" title="colorpicker">colorpicker</a></li>
|
|
<li class=""><a href="module_connection.html" title="connection">connection</a></li>
|
|
<li class=""><a href="module_container.html" title="container">container</a></li>
|
|
<li class=""><a href="module_cookie.html" title="cookie">cookie</a></li>
|
|
<li class=""><a href="module_datasource.html" title="datasource">datasource</a></li>
|
|
<li class=""><a href="module_datatable.html" title="datatable">datatable</a></li>
|
|
<li class=""><a href="module_datemath.html" title="datemath">datemath</a></li>
|
|
<li class=""><a href="module_dom.html" title="dom">dom</a></li>
|
|
<li class=""><a href="module_dragdrop.html" title="dragdrop">dragdrop</a></li>
|
|
<li class=""><a href="module_editor.html" title="editor">editor</a></li>
|
|
<li class=""><a href="module_element.html" title="element">element</a></li>
|
|
<li class=""><a href="module_element-delegate.html" title="element-delegate">element-delegate</a></li>
|
|
<li class=""><a href="module_event.html" title="event">event</a></li>
|
|
<li class=""><a href="module_event-delegate.html" title="event-delegate">event-delegate</a></li>
|
|
<li class=""><a href="module_event-mouseenter.html" title="event-mouseenter">event-mouseenter</a></li>
|
|
<li class=""><a href="module_event-simulate.html" title="event-simulate">event-simulate</a></li>
|
|
<li class=""><a href="module_get.html" title="get">get</a></li>
|
|
<li class=""><a href="module_history.html" title="history">history</a></li>
|
|
<li class=""><a href="module_imagecropper.html" title="imagecropper">imagecropper</a></li>
|
|
<li class=""><a href="module_imageloader.html" title="imageloader">imageloader</a></li>
|
|
<li class=""><a href="module_json.html" title="json">json</a></li>
|
|
<li class=""><a href="module_layout.html" title="layout">layout</a></li>
|
|
<li class=""><a href="module_logger.html" title="logger">logger</a></li>
|
|
<li class=""><a href="module_menu.html" title="menu">menu</a></li>
|
|
<li class=""><a href="module_paginator.html" title="paginator">paginator</a></li>
|
|
<li class=""><a href="module_profiler.html" title="profiler">profiler</a></li>
|
|
<li class=""><a href="module_profilerviewer.html" title="profilerviewer">profilerviewer</a></li>
|
|
<li class=""><a href="module_progressbar.html" title="progressbar">progressbar</a></li>
|
|
<li class=""><a href="module_resize.html" title="resize">resize</a></li>
|
|
<li class=""><a href="module_selector.html" title="selector">selector</a></li>
|
|
<li class=""><a href="module_slider.html" title="slider">slider</a></li>
|
|
<li class=""><a href="module_storage.html" title="Storage">Storage</a></li>
|
|
<li class=""><a href="module_stylesheet.html" title="stylesheet">stylesheet</a></li>
|
|
<li class=""><a href="module_swf.html" title="swf">swf</a></li>
|
|
<li class=""><a href="module_swfdetect.html" title="swfdetect">swfdetect</a></li>
|
|
<li class=""><a href="module_swfstore.html" title="swfstore">swfstore</a></li>
|
|
<li class=""><a href="module_tabview.html" title="tabview">tabview</a></li>
|
|
<li class=""><a href="module_treeview.html" title="treeview">treeview</a></li>
|
|
<li class=""><a href="module_uploader.html" title="uploader">uploader</a></li>
|
|
<li class=""><a href="module_yahoo.html" title="yahoo">yahoo</a></li>
|
|
<li class=""><a href="module_yuiloader.html" title="yuiloader">yuiloader</a></li>
|
|
<li class=""><a href="module_yuitest.html" title="yuitest">yuitest</a></li>
|
|
</ul>
|
|
</div>
|
|
|
|
<div id="classList" class="module">
|
|
<h4>Classes</h4>
|
|
<ul class="content">
|
|
<li class=""><a href="YAHOO.util.Anim.html" title="YAHOO.util.Anim">YAHOO.util.Anim</a></li>
|
|
<li class=""><a href="YAHOO.util.AnimMgr.html" title="YAHOO.util.AnimMgr">YAHOO.util.AnimMgr</a></li>
|
|
<li class=""><a href="YAHOO.util.Bezier.html" title="YAHOO.util.Bezier">YAHOO.util.Bezier</a></li>
|
|
<li class=""><a href="YAHOO.util.ColorAnim.html" title="YAHOO.util.ColorAnim">YAHOO.util.ColorAnim</a></li>
|
|
<li class=""><a href="YAHOO.util.Easing.html" title="YAHOO.util.Easing">YAHOO.util.Easing</a></li>
|
|
<li class=""><a href="YAHOO.util.Motion.html" title="YAHOO.util.Motion">YAHOO.util.Motion</a></li>
|
|
<li class=""><a href="YAHOO.util.Scroll.html" title="YAHOO.util.Scroll">YAHOO.util.Scroll</a></li>
|
|
</ul>
|
|
</div>
|
|
|
|
<div id="fileList" class="module">
|
|
<h4>Files</h4>
|
|
<ul class="content">
|
|
<li class="selected"><a href="Anim.js.html" title="Anim.js">Anim.js</a></li>
|
|
<li class=""><a href="AnimMgr.js.html" title="AnimMgr.js">AnimMgr.js</a></li>
|
|
<li class=""><a href="Bezier.js.html" title="Bezier.js">Bezier.js</a></li>
|
|
<li class=""><a href="ColorAnim.js.html" title="ColorAnim.js">ColorAnim.js</a></li>
|
|
<li class=""><a href="Easing.js.html" title="Easing.js">Easing.js</a></li>
|
|
<li class=""><a href="Motion.js.html" title="Motion.js">Motion.js</a></li>
|
|
<li class=""><a href="Scroll.js.html" title="Scroll.js">Scroll.js</a></li>
|
|
</ul>
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div id="ft">
|
|
<hr />
|
|
Copyright © 2010 Yahoo! Inc. All rights reserved.
|
|
</div>
|
|
</div>
|
|
<script type="text/javascript">
|
|
|
|
var ALL_YUI_PROPS = [{"access": "private", "host": "YAHOO.util.Anim", "name": "actualFrames", "url": "YAHOO.util.Anim.html#property_actualFrames", "type": "property"}, {"access": "", "host": "YAHOO.util.Anim", "name": "animate", "url": "YAHOO.util.Anim.html#method_animate", "type": "method"}, {"access": "", "host": "YAHOO.util.Anim", "name": "attributes", "url": "YAHOO.util.Anim.html#property_attributes", "type": "property"}, {"access": "", "host": "YAHOO.util.Easing", "name": "backBoth", "url": "YAHOO.util.Easing.html#method_backBoth", "type": "method"}, {"access": "", "host": "YAHOO.util.Easing", "name": "backIn", "url": "YAHOO.util.Easing.html#method_backIn", "type": "method"}, {"access": "", "host": "YAHOO.util.Easing", "name": "backOut", "url": "YAHOO.util.Easing.html#method_backOut", "type": "method"}, {"access": "", "host": "YAHOO.util.Easing", "name": "bounceBoth", "url": "YAHOO.util.Easing.html#method_bounceBoth", "type": "method"}, {"access": "", "host": "YAHOO.util.Easing", "name": "bounceIn", "url": "YAHOO.util.Easing.html#method_bounceIn", "type": "method"}, {"access": "", "host": "YAHOO.util.Easing", "name": "bounceOut", "url": "YAHOO.util.Easing.html#method_bounceOut", "type": "method"}, {"access": "private", "host": "YAHOO.util.AnimMgr", "name": "correctFrame", "url": "YAHOO.util.AnimMgr.html#method_correctFrame", "type": "method"}, {"access": "", "host": "YAHOO.util.Anim", "name": "currentFrame", "url": "YAHOO.util.Anim.html#property_currentFrame", "type": "property"}, {"access": "", "host": "YAHOO.util.AnimMgr", "name": "delay", "url": "YAHOO.util.AnimMgr.html#property_delay", "type": "property"}, {"access": "", "host": "YAHOO.util.Anim", "name": "doMethod", "url": "YAHOO.util.Anim.html#method_doMethod", "type": "method"}, {"access": "", "host": "YAHOO.util.Anim", "name": "duration", "url": "YAHOO.util.Anim.html#property_duration", "type": "property"}, {"access": "", "host": "YAHOO.util.Easing", "name": "easeBoth", "url": "YAHOO.util.Easing.html#method_easeBoth", "type": "method"}, {"access": "", "host": "YAHOO.util.Easing", "name": "easeBothStrong", "url": "YAHOO.util.Easing.html#method_easeBothStrong", "type": "method"}, {"access": "", "host": "YAHOO.util.Easing", "name": "easeIn", "url": "YAHOO.util.Easing.html#method_easeIn", "type": "method"}, {"access": "", "host": "YAHOO.util.Easing", "name": "easeInStrong", "url": "YAHOO.util.Easing.html#method_easeInStrong", "type": "method"}, {"access": "", "host": "YAHOO.util.Easing", "name": "easeNone", "url": "YAHOO.util.Easing.html#method_easeNone", "type": "method"}, {"access": "", "host": "YAHOO.util.Easing", "name": "easeOut", "url": "YAHOO.util.Easing.html#method_easeOut", "type": "method"}, {"access": "", "host": "YAHOO.util.Easing", "name": "easeOutStrong", "url": "YAHOO.util.Easing.html#method_easeOutStrong", "type": "method"}, {"access": "private", "host": "YAHOO.util.Anim", "name": "el", "url": "YAHOO.util.Anim.html#property_el", "type": "property"}, {"access": "", "host": "YAHOO.util.Easing", "name": "elasticBoth", "url": "YAHOO.util.Easing.html#method_elasticBoth", "type": "method"}, {"access": "", "host": "YAHOO.util.Easing", "name": "elasticIn", "url": "YAHOO.util.Easing.html#method_elasticIn", "type": "method"}, {"access": "", "host": "YAHOO.util.Easing", "name": "elasticOut", "url": "YAHOO.util.Easing.html#method_elasticOut", "type": "method"}, {"access": "", "host": "YAHOO.util.AnimMgr", "name": "fps", "url": "YAHOO.util.AnimMgr.html#property_fps", "type": "property"}, {"access": "", "host": "YAHOO.util.Anim", "name": "getAttribute", "url": "YAHOO.util.Anim.html#method_getAttribute", "type": "method"}, {"access": "", "host": "YAHOO.util.Anim", "name": "getDefaultUnit", "url": "YAHOO.util.Anim.html#method_getDefaultUnit", "type": "method"}, {"access": "", "host": "YAHOO.util.Anim", "name": "getEl", "url": "YAHOO.util.Anim.html#method_getEl", "type": "method"}, {"access": "", "host": "YAHOO.util.Bezier", "name": "getPosition", "url": "YAHOO.util.Bezier.html#method_getPosition", "type": "method"}, {"access": "", "host": "YAHOO.util.Anim", "name": "getStartTime", "url": "YAHOO.util.Anim.html#method_getStartTime", "type": "method"}, {"access": "", "host": "YAHOO.util.Anim", "name": "init", "url": "YAHOO.util.Anim.html#method_init", "type": "method"}, {"access": "private", "host": "YAHOO.util.Anim", "name": "isAnimated", "url": "YAHOO.util.Anim.html#property_isAnimated", "type": "property"}, {"access": "", "host": "YAHOO.util.Anim", "name": "isAnimated", "url": "YAHOO.util.Anim.html#method_isAnimated", "type": "method"}, {"access": "", "host": "YAHOO.util.Anim", "name": "method", "url": "YAHOO.util.Anim.html#property_method", "type": "property"}, {"access": "private", "host": "YAHOO.util.Anim", "name": "_onComplete", "url": "YAHOO.util.Anim.html#property__onComplete", "type": "property"}, {"access": "", "host": "YAHOO.util.Anim", "name": "onComplete", "url": "YAHOO.util.Anim.html#event_onComplete", "type": "event"}, {"access": "private", "host": "YAHOO.util.Anim", "name": "_onStart", "url": "YAHOO.util.Anim.html#property__onStart", "type": "property"}, {"access": "", "host": "YAHOO.util.Anim", "name": "onStart", "url": "YAHOO.util.Anim.html#event_onStart", "type": "event"}, {"access": "private", "host": "YAHOO.util.Anim", "name": "_onTween", "url": "YAHOO.util.Anim.html#property__onTween", "type": "property"}, {"access": "private", "host": "YAHOO.util.Anim", "name": "onTween", "url": "YAHOO.util.Anim.html#method_onTween", "type": "method"}, {"access": "", "host": "YAHOO.util.Anim", "name": "onTween", "url": "YAHOO.util.Anim.html#event_onTween", "type": "event"}, {"access": "", "host": "YAHOO.util.ColorAnim", "name": "parseColor", "url": "YAHOO.util.ColorAnim.html#method_parseColor", "type": "method"}, {"access": "private", "host": "YAHOO.util.AnimMgr", "name": "queue", "url": "YAHOO.util.AnimMgr.html#property_queue", "type": "property"}, {"access": "", "host": "YAHOO.util.AnimMgr", "name": "registerElement", "url": "YAHOO.util.AnimMgr.html#method_registerElement", "type": "method"}, {"access": "", "host": "YAHOO.util.AnimMgr", "name": "run", "url": "YAHOO.util.AnimMgr.html#method_run", "type": "method"}, {"access": "", "host": "YAHOO.util.Anim", "name": "setAttribute", "url": "YAHOO.util.Anim.html#method_setAttribute", "type": "method"}, {"access": "", "host": "YAHOO.util.Anim", "name": "setEl", "url": "YAHOO.util.Anim.html#method_setEl", "type": "method"}, {"access": "private", "host": "YAHOO.util.Anim", "name": "setRuntimeAttribute", "url": "YAHOO.util.Anim.html#method_setRuntimeAttribute", "type": "method"}, {"access": "", "host": "YAHOO.util.AnimMgr", "name": "start", "url": "YAHOO.util.AnimMgr.html#method_start", "type": "method"}, {"access": "private", "host": "YAHOO.util.Anim", "name": "startTime", "url": "YAHOO.util.Anim.html#property_startTime", "type": "property"}, {"access": "", "host": "YAHOO.util.Anim", "name": "stop", "url": "YAHOO.util.Anim.html#method_stop", "type": "method"}, {"access": "", "host": "YAHOO.util.AnimMgr", "name": "stop", "url": "YAHOO.util.AnimMgr.html#method_stop", "type": "method"}, {"access": "private", "host": "YAHOO.util.AnimMgr", "name": "thread", "url": "YAHOO.util.AnimMgr.html#property_thread", "type": "property"}, {"access": "", "host": "YAHOO.util.Anim", "name": "toString", "url": "YAHOO.util.Anim.html#method_toString", "type": "method"}, {"access": "", "host": "YAHOO.util.Anim", "name": "totalFrames", "url": "YAHOO.util.Anim.html#property_totalFrames", "type": "property"}, {"access": "private", "host": "YAHOO.util.AnimMgr", "name": "tweenCount", "url": "YAHOO.util.AnimMgr.html#property_tweenCount", "type": "property"}, {"access": "private", "host": "YAHOO.util.AnimMgr", "name": "unRegister", "url": "YAHOO.util.AnimMgr.html#method_unRegister", "type": "method"}, {"access": "", "host": "YAHOO.util.Anim", "name": "useSeconds", "url": "YAHOO.util.Anim.html#property_useSeconds", "type": "property"}];
|
|
</script>
|
|
</body>
|
|
</html>
|