6 window.requestAnimationFrame ||
\r
7 window.webkitRequestAnimationFrame ||
\r
8 window.mozRequestAnimationFrame ||
\r
9 window.oRequestAnimationFrame ||
\r
10 window.msRequestAnimationFrame ||
\r
13 window.cancelRequestAnimationFrame ||
\r
14 window.webkitCancelAnimationFrame ||
\r
15 window.webkitCancelRequestAnimationFrame ||
\r
16 window.mozCancelRequestAnimationFrame ||
\r
17 window.oCancelRequestAnimationFrame ||
\r
18 window.msCancelRequestAnimationFrame ||
\r
28 busy : false, // for Opera7
\r
29 //frameBusy : false,
\r
31 REQ_FRAME_LIST : [],
\r
35 var next = X.Timer.next,
\r
36 list = X.Timer.TICKET_LIST,
\r
44 X.Timer.busy = true;
\r
48 if( 0 < ( q.last -= next ) ) continue;
\r
53 r = X.Callback._proxyCallback( q );
\r
58 if( r & X.Callback.UN_LISTEN || c === 1 ){
\r
59 list.splice( i, 1 );
\r
60 //f.kill && f.kill();
\r
63 if( 1 < c ) --q.count;
\r
66 X.Timer.timerId = 0;
\r
67 X.Timer.busy = false;
\r
70 _update : function(){
\r
71 var list = X.Timer.TICKET_LIST,
\r
76 X.Timer.timerId && window.clearTimeout( X.Timer.timerId );
\r
77 X.Timer.timerId = 0;
\r
81 ( l = list[ --i ].last ) < n && ( n = l );
\r
83 if( n < X.Timer.next || X.Timer.timerId === 0 ){
\r
84 X.Timer.timerId && window.clearTimeout( X.Timer.timerId );
\r
85 X.Timer.timerId = window.setTimeout( X.Timer._loop, X.Timer.INTERVAL_TIME * n );
\r
86 X.Timer.endTime = X.getTime() + X.Timer.INTERVAL_TIME * n; // iOS
\r
92 _onEnterFrame : function ( time ){
\r
93 var list = X.Timer.REQ_FRAME_LIST,
\r
96 //this.frameBusy = true;
\r
97 time = time || X.getTime();
\r
98 console.log( X.getTime() + ' , ' + time );
\r
99 for( ; i < l; ++i ){
\r
104 X.Callback._proxyCallback( q );
\r
109 //f.kill && f.kill();
\r
111 //this.frameBusy = false;
\r
112 list.splice( 0, l );
\r
113 if( list.length ) X.Timer.requestID = _enterFrame( X.Timer._onEnterFrame );
\r
116 add : function( time, opt_count, args1, args2, args3 ){
\r
117 var list = X.Timer.TICKET_LIST,
\r
119 time = time < X.Timer.INTERVAL_TIME ? 1 : time / X.Timer.INTERVAL_TIME | 0; // 正の数で使える「Math.floor(x)」を「(x | 0)」に;
\r
121 if( !X.Type.isNumber( opt_count ) ){
\r
128 hash = X.Callback._classifyCallbackArgs( args1, args2, args3 );
\r
129 if( !hash ) return -1; // dev only
\r
131 if( !hash.k ) hash = { f : hash };
\r
134 hash.count = opt_count;
\r
135 hash.uid = ++X.Timer.uid;
\r
136 list[ list.length ] = hash;
\r
138 !X.Timer.busy && X.Timer._update();
\r
139 return X.Timer.uid;
\r
141 once : function( time, args1, args2, args3 ){
\r
142 return X.Timer.add( time, 1, args1, args2, args3 );
\r
144 remove : function( uid ){
\r
145 var list = X.Timer.TICKET_LIST,
\r
152 if( ( q = list[ --i ] ).uid === uid ){
\r
153 list.splice( i, 1 );
\r
155 //f.kill && f.kill();
\r
156 !X.Timer.busy && ( /* q[ INDEX_COUNT ] <= next || */ l === 1 ) && X.Timer._update();
\r
163 requestFrame : _enterFrame ?
\r
164 (function( args1, args2, args3 ){
\r
165 var i = X.Timer.REQ_FRAME_LIST.length,
\r
167 i === 0 && ( X.Timer.requestID = _enterFrame( X.Timer._onEnterFrame ) );
\r
168 f = X.Timer.REQ_FRAME_LIST[ i ] = X.Callback._classifyCallbackArgs( args1, args2, args3 );
\r
169 return f.uid = ++X.Timer.uid;
\r
171 (function( args1, args2, args3 ){
\r
172 var i = X.Timer.REQ_FRAME_LIST.length,
\r
174 i === 0 && ( X.Timer.requestID = X.Timer.add( 0, 1, X.Timer._onEnterFrame ) );
\r
175 f = X.Timer.REQ_FRAME_LIST[ i ] = X.Callback._classifyCallbackArgs( args1, args2, args3 );
\r
176 return f.uid = ++X.Timer.uid;
\r
179 cancelFrame : _cancelFrame ?
\r
181 var list = X.Timer.REQ_FRAME_LIST,
\r
186 if( ( f = list[ --i ] ).uid < uid ) break;
\r
187 if( f.uid === uid ){
\r
190 list.splice( i, 1 );
\r
192 //f.kill && f.kill();
\r
193 l === 1 && _cancelFrame( X.Timer.requestID );
\r
199 var list = X.Timer.REQ_FRAME_LIST,
\r
204 if( ( f = list[ --i ] ).uid < uid ) break;
\r
205 if( f.uid === uid ){
\r
206 list.splice( i, 1 );
\r
208 //f.kill && f.kill();
\r
209 l === 1 && X.Timer.remove( X.Timer.requestID );
\r
217 // http://havelog.ayumusato.com/develop/javascript/e528-ios6_scrolling_timer_notcall.html
\r
218 // iOS6 スクロール中のタイマー発火絡みのバグ備忘
\r
220 window.addEventListener( 'scroll', function(){
\r
221 if( X.Timer.timerId ){
\r
222 window.clearTimeout( X.Timer.timerId );
\r
223 X.Timer.timerId = window.setTimeout( X.Timer._loop, Math.max( 0, X.Timer.endTime - X.getTime() ) );
\r
228 if( X.UA.IE < 5 || X.UA.MacIE ){
\r
229 X.Timer[ '_ie_loop' ] = X.Timer._loop;
\r
230 X.Timer._loop = 'X.Timer._ie_loop()';
\r
233 console.log( 'X.Core.Timer' );
\r