From: itozyun Date: Thu, 22 Oct 2015 01:29:57 +0000 (+0900) Subject: Version 0.6.181, fix X.UA & X.HTMLAudio & X.AudioSprite. X-Git-Url: http://git.osdn.jp/view?p=pettanr%2FclientJs.git;a=commitdiff_plain;h=a4c3d3a22b13112b3317a6ffd3eff2272c2264f1 Version 0.6.181, fix X.UA & X.HTMLAudio & X.AudioSprite. --- diff --git a/0.6.x/js/01_core/02_XUA.js b/0.6.x/js/01_core/02_XUA.js index ec338a8..4a6228c 100644 --- a/0.6.x/js/01_core/02_XUA.js +++ b/0.6.x/js/01_core/02_XUA.js @@ -231,9 +231,9 @@ var X_UA = X[ 'UA' ] = {}, * @type {boolean} */ X_UA[ 'Linux' ] = true; - - if( dua.indexOf( 'Android ' ) !== -1 ){ - v = dua.split( 'Android ' )[ 1 ].split( '.' ); + + if( v = dua.split( 'Android ' )[ 1 ] ){ + v = v.split( '.' ); /** * @alias X.UA.AndroidMajor * @type {number} @@ -260,31 +260,19 @@ var X_UA = X[ 'UA' ] = {}, * @alias X.UA.Android * @type {number} */ - X_UA[ 'Android' ] = X_UA[ 'AndroidMajor' ] + X_UA[ 'AndroidMinor' ] / 10; + X_UA[ 'Android' ] = X_UA[ 'AndroidMajor' ] + X_UA[ 'AndroidMinor' ] / 10; console.log( '>> Android : ' + X_UA[ 'Android' ] ); - } else - if( dua.indexOf( 'Android;' ) !== -1 ){ - // Fennec41- 用 - // https://developer.mozilla.org/ja/docs/Gecko_user_agent_string_reference - // バージョン 41 以降の Android 版 Firefox では platform トークンに Android バージョンが含まれます。 - // 相互運用性向上のため、Android 4 以前のバージョンでブラウザが動作している場合は 4.4 と出力します。 - // Android バージョン 4 以降では実際のバージョン番号が出力されます。 - // なお、Gecko エンジンはすべての Android バージョンに対して同じ機能を提供しています。 - X_UA[ 'Android' ] = 2.2; }; }; if( window.opera ){ - i = dua.indexOf( 'Opera' ); // Opera/ - j = dua.indexOf( 'Version/' ); + i = dua.split( 'Opera' )[ 1 ]; // Opera/ + j = dua.split( 'Version/' )[ 1 ]; /** * @alias X.UA.Opera * @type {number} */ - X_UA[ 'Opera' ] = v = Math.max( - i !== -1 ? parseFloat( dua.substr( i + 6 ) ) : 0, - j !== -1 ? parseFloat( dua.substr( j + 8 ) ) : 0, - tv ); + X_UA[ 'Opera' ] = v = Math.max( parseFloat( i ) || 0, parseFloat( j ) || 0, tv ); /** * memo:closure compiler で minify するとOpera7で動かない * --compilation_level WHITESPACE_ONLY --formatting pretty_print <- 動く @@ -297,57 +285,69 @@ var X_UA = X[ 'UA' ] = {}, * @type {boolean} */ X_UA[ 'Opera78' ] = v < 9; - /** - * @alias X.UA.OperaMini - * @type {boolean} - */ - X_UA[ 'OperaMini' ] = 0 < dua.indexOf('Opera Mini'); - /** - * @alias X.UA.OperaMobile - * @type {boolean} - */ - X_UA[ 'OperaMobile' ] = 0 < dua.indexOf('Opera Mobi'); - /** - * @alias X.UA.OperaTablet - * @type {boolean} - */ - X_UA[ 'OperaTablet' ] = 0 < dua.indexOf('Opera Tablet'); - /** - * @alias X.UA.Wii - * @type {boolean} - */ - X_UA[ 'Wii' ] = dua.indexOf( 'Nintendo Wii' ) !== -1; - /** - * @alias X.UA.NDS - * @type {boolean} - */ - X_UA[ 'NDS' ] = dua.indexOf( 'Nitro' ) !== -1; + + if( 0 < dua.indexOf( 'Opera Mini' ) ) + /** + * @alias X.UA.OperaMini + * @type {boolean} + */ + X_UA[ 'OperaMini' ] = true; + + if( 0 < dua.indexOf( 'Opera Mobi' ) ) + /** + * @alias X.UA.OperaMobile + * @type {boolean} + */ + X_UA[ 'OperaMobile' ] = true; + + if( 0 < dua.indexOf('Opera Tablet') ) + /** + * @alias X.UA.OperaTablet + * @type {boolean} + */ + X_UA[ 'OperaTablet' ] = true; + + if( 0 < dua.indexOf( 'Nintendo Wii' ) ) + /** + * @alias X.UA.Wii + * @type {boolean} + */ + X_UA[ 'Wii' ] = true; + + if( 0 < dua.indexOf( 'Nitro' ) ) + /** + * @alias X.UA.NDS + * @type {boolean} + */ + X_UA[ 'NDS' ] = true; + console.log( '>> Opera : ' + v ); } else // Mozilla/5.0 (Windows NT 6.3; Trident/7.0; rv:11.0) like Gecko - if( document.all || dav.indexOf( 'Trident/' ) !== -1 ){ - /** - * @alias X.UA.ActiveX - * @type {boolean} - */ - X_UA[ 'ActiveX' ] = !!window[ 'ActiveXObject' ]; - /** - * documentモードを考慮しないIEのバージョン - * @alias X.UA._IE - * @type {number} - */ - X_UA[ '_IE' ] = parseFloat(dua.split('MSIE ')[1]) || parseFloat(dua.split('rv:')[1]) || parseFloat(dav.split('MSIE ')[1]) || 0; + if( ( v = dav.split( 'Trident/' )[ 1 ] ) || document.all ){ + if( v = parseFloat( v ) ) /** * IE11 の互換モードの navigator.appVersion にも Trident/7.0 が書かれているため互換モードか?判定ができるc * @alias X.UA.Trident * @type {number} */ - X_UA[ 'Trident' ] = parseFloat(dav.split('Trident/')[1]) || 0; + X_UA[ 'Trident' ] = v; - tridentToVer = X_UA[ 'Trident' ] ? ( X_UA[ 'Trident' ] + 4 | 0 ) : X_UA[ '_IE' ]; + if( window[ 'ActiveXObject' ] ) + /** + * @alias X.UA.ActiveX + * @type {boolean} + */ + X_UA[ 'ActiveX' ] = true; + + v = parseFloat( dua.split( 'MSIE ' )[ 1 ] ) || + parseFloat( dua.split( 'rv:' )[ 1 ] ) || + parseFloat( dav.split( 'MSIE ' )[ 1 ] ) || 0; + + tridentToVer = X_UA[ 'Trident' ] ? ( X_UA[ 'Trident' ] + 4 | 0 ) : v; - if( tridentToVer !== X_UA[ '_IE' ] ){ + if( tridentToVer !== v ){ /** * IE10 以上の互換モードを使用している場合、そのバージョン * @alias X.UA.IEHost @@ -443,7 +443,7 @@ var X_UA = X[ 'UA' ] = {}, X_UA[ 'MacIE' ] = true; }; - if( dua.toLowerCase().indexOf( 'iemobile' ) !== -1 || X_UA[ 'WinCE' ] ){ + if( 0 < dua.toLowerCase().indexOf( 'iemobile' ) || X_UA[ 'WinCE' ] ){ /** * @alias X.UA.IEMobile * @type {boolean} @@ -451,7 +451,7 @@ var X_UA = X[ 'UA' ] = {}, X_UA[ 'IEMobile' ] = true; }; - if( dua.toLowerCase().indexOf( 'windows phone' ) !== -1 || 0 < dav.indexOf( 'ZuneWP' ) ){ + if( 0 < dua.toLowerCase().indexOf( 'windows phone' ) || 0 < dav.indexOf( 'ZuneWP' ) ){ /** * @alias X.UA.WinPhone * @type {boolean} @@ -464,13 +464,13 @@ var X_UA = X[ 'UA' ] = {}, } else // - if( ( i = dua.indexOf( 'NetFront\/' ) !== -1 ) ){ + if( v = dua.split( 'NetFront\/' )[ 1 ] ){ /** * http://qa.support.sony.jp/solution/S0812181056444/common/nfb34_dom_200jp/dom_dom0_JP.html * @alias X.UA.NetFront * @type {number} */ - X_UA[ 'NetFront' ] = parseFloat( dua.substr( i + 9 ) ) || 0.1; + X_UA[ 'NetFront' ] = parseFloat( v ) || 0.1; console.log( '>> NetFront : ' + X_UA[ 'NetFront' ] ); } else @@ -479,7 +479,7 @@ var X_UA = X[ 'UA' ] = {}, console.log( '>> NetFront : ' + X_UA[ 'NetFront' ] ); } else - if( ( i = dua.toUpperCase().indexOf( 'PLAYSTATION 3' ) !== -1 ) ){ + if( v = dua.toUpperCase().split( 'PLAYSTATION 3' )[ 1 ] ){ /** * PlayStation 3 システムバージョン 4.10 未満の SONY 独自ブラウザ * http://www.useragentstring.com/pages/Playstation%203/ @@ -490,11 +490,11 @@ var X_UA = X[ 'UA' ] = {}, * @alias X.UA.PS3 * @type {number} */ - X_UA[ 'PS3' ] = parseFloat( dua.substr( i + 15 ) ) || 0.1; + X_UA[ 'PS3' ] = parseFloat( v ) || 0.1; console.log( '>> PS3 : ' + X_UA[ 'PS3' ] ); } else - if( ( i = dua.indexOf( 'iCab' ) !== -1 ) ){ + if( v = dua.split( 'iCab' )[ 1 ] ){ /** * http://www.useragentstring.com/pages/iCab/ * iCab/3.0.2 (Macintosh; U; PPC Mac OS X) @@ -502,12 +502,12 @@ var X_UA = X[ 'UA' ] = {}, * @alias X.UA.iCab * @type {number} */ - X_UA[ 'iCab' ] = parseFloat( dua.substr( i + 5 ) ) || 0.1; + X_UA[ 'iCab' ] = parseFloat( v ) || 0.1; console.log( '>> iCab : ' + X_UA[ 'iCab' ] ); } else - if( 0 < dua.indexOf( 'Gecko\/' ) && ( i = dua.indexOf( 'rv:' ) ) ){ - v = dua.substr( i + 3 ).split( '.' ); + if( 0 < dua.indexOf( 'Gecko\/' ) && ( v = dua.split( 'rv:' )[ 1 ] ) ){ + v = v.split( '.' ); /** * メジャーバージョン + マイナーバージョン * @alias X.UA.Gecko @@ -531,14 +531,28 @@ var X_UA = X[ 'UA' ] = {}, */ X_UA[ 'GeckoPatch' ] = parseFloat( v[ 2 ] ) || 0; + // Fennec41- 用 + // https://developer.mozilla.org/ja/docs/Gecko_user_agent_string_reference + // バージョン 41 以降の Android 版 Firefox では platform トークンに Android バージョンが含まれます。 + // 相互運用性向上のため、Android 4 以前のバージョンでブラウザが動作している場合は 4.4 と出力します。 + // Android バージョン 4 以降では実際のバージョン番号が出力されます。 + // なお、Gecko エンジンはすべての Android バージョンに対して同じ機能を提供しています。 + if( dua.indexOf( 'Android 4.4; Mobile;' ) !== -1 || dua.indexOf( 'Android 4.4; Tablet;' ) !== -1 ){ + X_UA[ 'Android' ] = '2.3+'; + } else + if( dua.indexOf( 'Android;' ) !== -1 ){ + X_UA[ 'Android' ] = '2.2+'; + }; + + // TODO PC版 Fennec もある //Fennec - if( ( i = dua.indexOf( 'Fennec/' ) ) !== -1 ){ + if( v = dua.split( 'Fennec/' )[ 1 ] ){ /** * Mozilla/5.0 (Android; Linux armv7l; rv:9.0) Gecko/20111216 Firefox/9.0 Fennec/9.0 * @alias X.UA.Fennec * @type {number} */ - X_UA[ 'Fennec' ] = parseFloat( dua.substr( i + 7 ) ); + X_UA[ 'Fennec' ] = parseFloat( v ); console.log( '>> Fennec : ' + X_UA[ 'Fennec' ] + ', Gecko : ' + X_UA[ 'Gecko' ] ); } else if( X_UA[ 'Android' ] ){ @@ -563,13 +577,13 @@ var X_UA = X[ 'UA' ] = {}, } else //Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.7.2) Gecko/20040804 Netscape/7.2 (ax) //Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.7.5) Gecko/20070321 Netscape/8.1.3 - if( ( i = dua.indexOf( 'Netscape/' ) ) !== -1 ){ - X_UA[ 'NN' ] = parseFloat( dua.substr( i + 9 ) ) || 7; + if( v = dua.split( 'Netscape/' )[ 1 ] ){ + X_UA[ 'NN' ] = parseFloat( v ) || 7; console.log( '>> NN : ' + X_UA[ 'NN' ] + ', Gecko : ' + X_UA[ 'Gecko' ] ); } else //Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.12) Gecko/20080219 Firefox/2.0.0.12 Navigator/9.0.0.6 - if( ( i = dua.indexOf( 'Navigator/' ) ) !== -1 ){ - X_UA[ 'NN' ] = parseFloat( dua.substr( i + 10 ) ) || 9; + if( v = dua.split( 'Navigator/' )[ 1 ] ){ + X_UA[ 'NN' ] = parseFloat( v ) || 9; console.log( '>> NN : ' + X_UA[ 'NN' ] + ', Gecko : ' + X_UA[ 'Gecko' ] ); }; @@ -577,8 +591,7 @@ var X_UA = X[ 'UA' ] = {}, } else // Android 標準ブラウザ AOSP と ChromeWeb View, Sブラウザがある - if( ( v = X_UA[ 'Android' ] ) && - ( dua.indexOf( 'Chrome\/' ) < 0 || 0 < dua.indexOf( 'Version\/' ) ) ){ // Chrome/ を含まない または Version/ を含む + if( ( v = X_UA[ 'Android' ] ) && ( dua.indexOf( 'Chrome\/' ) < 0 || 0 < dua.indexOf( 'Version\/' ) ) ){ // Chrome/ を含まない または Version/ を含む /* if( window.chrome ){ // Android3.1 のAOSPブラウザで .chrome がいた、、、 } else */ @@ -613,24 +626,24 @@ var X_UA = X[ 'UA' ] = {}, * SC-04E、SC-01F、SC-02F、 SC-04F、SCL22、SCL23など */ } else - // Blink Chrome & Blink Opera + if( v = parseFloat( dua.split( 'OPR/' )[ 1 ] ) ){ + /** + * @alias X.UA.BlinkOpera + * @type {number} + */ + X_UA[ 'BlinkOpera' ] = v; + + X_UA[ 'Blink' ] = parseFloat( dua.split( 'Chrome/' )[ 1 ] ); + } else if( window.chrome ){ /** * @alias X.UA.Blink * @type {number} */ X_UA[ 'Blink' ] = parseFloat( dua.split( 'Chrome/' )[ 1 ] ); - - if( v = parseFloat( dua.split( 'OPR/' )[ 1 ] ) ){ - /** - * @alias X.UA.BlinkOpera - * @type {number} - */ - X_UA[ 'BlinkOpera' ] = v; - }; + console.log( '>>Blink : ' + X_UA[ 'Blink' ] ); - } else if( dav.indexOf( 'Konqueror' ) !== -1 ){ /** @@ -641,47 +654,40 @@ var X_UA = X[ 'UA' ] = {}, console.log( '>>Khtml : ' + X_UA[ 'Khtml' ] ); } else - - if( i = parseFloat(dua.split('WebKit\/')[1]) ){ + if( v = parseFloat( dua.split( 'WebKit\/' )[ 1 ] ) ){ /** * @alias X.UA.WebKit * @type {number} */ - X_UA[ 'WebKit' ] = i; + X_UA[ 'WebKit' ] = v; - if( v = parseFloat(dua.split('Chrome\/')[1]) ){ + if( v = parseFloat( dua.split( 'Chrome\/' )[ 1 ] ) ){ /** * @alias X.UA.Chrome * @type {number} */ X_UA[ 'Chrome' ] = v; - }; - - // TODO webkit Opera - - console.log( '>>Webkit : ' + X_UA[ 'WebKit' ] ); - - if( i && !X_UA[ 'Chrome' ] && dua.indexOf( 'Safari' ) !== -1 ){ - if( dav.indexOf( 'Version/' ) !== -1 ){ + } else + if( dua.indexOf( 'Safari' ) !== -1 ){ + if( v = parseFloat( dav.split( 'Version/' )[ 1 ] ) ){ /** * @alias X.UA.Safari * @type {number} */ - X_UA[ 'Safari' ] = parseFloat( dav.split('Version/')[1] ); - } else { - if( i <= 528.16 ){ - X_UA[ 'Safari' ] = i < 73 ? 0.8 : - i < 85 ? 0.9 : - i < 100 ? 1 : - i < 125 ? 1.1 : - i < 312 ? 1.2 : - i < 412 ? 1.3 : - i <= 419.3 ? 2 : - i <= 525.13 ? 3 : - i <= 525.25 ? 3.1 : 3.2; - }; + X_UA[ 'Safari' ] = v; + } else + if( i <= 528.16 ){ + X_UA[ 'Safari' ] = i < 73 ? 0.8 : + i < 85 ? 0.9 : + i < 100 ? 1 : + i < 125 ? 1.1 : + i < 312 ? 1.2 : + i < 412 ? 1.3 : + i <= 419.3 ? 2 : + i <= 525.13 ? 3 : + i <= 525.25 ? 3.1 : 3.2; }; - }; + }; console.log( '>> Webkit : ' + X_UA[ 'WebKit' ] + ' Safari : ' + X_UA[ 'Safari' ] ); diff --git a/0.6.x/js/07_audio/02_XHTMLAudio.js b/0.6.x/js/07_audio/02_XHTMLAudio.js index 10a5bfd..1ab50db 100644 --- a/0.6.x/js/07_audio/02_XHTMLAudio.js +++ b/0.6.x/js/07_audio/02_XHTMLAudio.js @@ -17,6 +17,9 @@ * memo * 1. AOSP4.1 iframe 内の Audio は親に focus が移っても再生を継続する * 2. AOSP oggはシークが乱れる m4a, mp3 は優秀 + * + * http://unolabo.boo.jp/archives/2011/06/13-iphone%E3%81%AEaudio%E5%91%A8%E3%82%8A%E3%81%AE%E3%83%A1%E3%83%A2.html + * 【JS】iPhoneのAudio周りのメモ iOS4.0 と 4.2 の違い */ /* * durationFix @@ -59,13 +62,13 @@ var // Gecko PC + Android でseek時に再生がしばしば止まる問題の修正 X_HTMLAudio_needPlayForSeek = X_UA[ 'Gecko' ], // - X_HTMLAudio_pauseFix = ( X_UA[ 'Windows' ] && 12 <= X_UA[ 'Opera' ] && 0 < ' XP XPSP2 2003|XP64'.indexOf( X_UA[ 'Windows' ] ) ), // XP + Opera12 のみ? + X_HTMLAudio_pauseFix = 12 <= X_UA[ 'Opera' ] && 0 < ' XP XPSP2 2003|XP64'.indexOf( X_UA[ 'Windows' ] ), // XP + Opera12 のみ? - X_HTMLAudio_need1stTouch = X_UA[ 'iOS' ] || 4 <= X_UA[ 'AOSP' ] || X_UA[ 'ChromeWV' ] || X_UA[ 'WinPhone' ] || ( X_UA[ 'Blink' ] && X_UA[ 'Android' ] ), + X_HTMLAudio_need1stTouch = X_UA[ 'iOS' ] || 4.2 <= X_UA[ 'AOSP' ] || X_UA[ 'ChromeWV' ] || X_UA[ 'WinPhone' ] || ( X_UA[ 'Blink' ] && X_UA[ 'Android' ] ), X_HTMLAudio_playTrigger = ( X_UA[ 'WinPhone' ] && X_UA[ 'IE9' ] ) ? 'canplay' : X_UA[ 'iOS' ] ? 'suspend' : X_UA[ 'Blink' ] ? 'stalled' : 'canplaythrough', - X_HTMLAudio_durationFix = X_UA[ 'iOS' ] || X_UA[ 'ChromeWV' ] || ( X_UA[ 'Windows' ] && 12 <= X_UA[ 'Opera' ] ) || ( X_UA[ 'WinPhone' ] && X_UA[ 'IE9' ] ), + X_HTMLAudio_durationFix = X_UA[ 'iOS' ] || X_UA[ 'ChromeWV' ] || ( X_UA[ 'WinPhone' ] && X_UA[ 'IE9' ] ) || ( X_UA[ 'Windows' ] && 12 <= X_UA[ 'Opera' ] ), X_HTMLAudio_shortPlayFix = X_UA[ 'AOSP' ]; // Android 4.1.1 でも遭遇 @@ -77,7 +80,7 @@ if( X_Audio_constructor ){ { _closed : true, _loaded : false, - _ready : false, + _ready : false, _src : '', _touchRequested : false, @@ -118,12 +121,20 @@ if( X_Audio_constructor ){ raw.style.cssText = 'position:absolute;bottom:0;left:-50px;width:100px;height:100px;opacity:0;'; raw.controls = false; raw.WebKitPlaysInline = true; - raw.src = source; X_elmBody.appendChild( raw ); } else { - raw = X_TEMP.rawAudio || new X_Audio_constructor( source ); + raw = X_TEMP.rawAudio || new X_Audio_constructor( '' ); // X_Doc_create( 'audio', { src : source } )[ 'appendTo' ]( X.Doc.body ); - raw.autobuffer = raw.autoplay = false; + + raw.preload = 'auto'; + //if( X_UA[ 'AOSP' ] < 4.2 ){ + raw.autoplay = true; //raw.autobuffer = true; // Android 4.0-4.1.x で必要 + //} else { + // raw.autoplay = raw.autobuffer = false; + //}; + //raw.autoplay = raw.autobuffer = raw.loop = false; // loop を使えば ended で止まること回避できるかも 但し ended イベントが起きなくなる + + if( X_TEMP.rawAudio ) delete X_TEMP.rawAudio; }; this[ '_rawObject' ] = raw; @@ -139,7 +150,6 @@ if( X_Audio_constructor ){ 'playing', 'waiting', 'seeking', 'durationchange', 'timeupdate', 'ended' ] ); - this[ 'listen' ]( [ 'loadstart', 'load', 'progress', 'error', @@ -149,11 +159,8 @@ if( X_Audio_constructor ){ 'playing', 'waiting', 'seeking', 'durationchange', 'timeupdate', 'ended' ], this.onDebug ); - if( X_TEMP.rawAudio ){ - raw.src = source; - X_UA[ 'AOSP' ] < 3 && raw.load(); - delete X_TEMP.rawAudio; - }; + raw.src = source; + raw.load(); // Android4.1.1 HTL21 では必要! }, onDebug : function( e ){ @@ -161,7 +168,7 @@ if( X_Audio_constructor ){ type : X_EVENT_DEBUG, 'rawEvent' : e.type, current : this.getActualCurrentTime() | 0, - duration : this.duration | 0 } ); + duration : this[ '_rawObject' ].duration } ); }, handleEvent : function( e ){ @@ -230,15 +237,15 @@ if( X_Audio_constructor ){ if( this._durationFixPhase & 3 ){ // 1 or 2 duration = raw.duration; } else - if( this.getActualCurrentTime() === this._lastCurrentTime ){ + if( ( now = this.getActualCurrentTime() ) === this._lastCurrentTime ){ eventType = X_EVENT_MEDIA_WAITING; } else { - this._lastCurrentTime = this.getActualCurrentTime(); + this._lastCurrentTime = now; // *1 rm if( this.playing ){ end = X_Audio_getEndTime( this ) + this._shortPlayFixTime; - now = this.getActualCurrentTime(); //console.log( now + ' / ' + end ); + // || now < this._lastCurrentTime // loop した場合 if( 0 + end <= 0 + now ){ // 0+ なぜか iem9 で必要,,, if( this.autoLoop ){ console.log( '☆★☆ 曲の最後に到達 @timeupdate now-end:' + ( now - end ) ); @@ -250,6 +257,7 @@ if( X_Audio_constructor ){ }; } else { eventType = X_EVENT_MEDIA_PLAYING; + // *1 this._lastCurrentTime = now; }; }; }; @@ -272,9 +280,9 @@ if( X_Audio_constructor ){ if( X_HTMLAudio_volumeFix ){ raw.volume = this.gain; }; - if( X_HTMLAudio_currentTimeFix && !this._currentFixStart ){ + //if( X_HTMLAudio_currentTimeFix && !this._currentFixStart ){ //this._currentFixStart = X_Timer_now(); // 正確な再生開始時間に補正 - }; + //}; eventType = !this._durationFixSkip && !this._endedFixON ? X_EVENT_MEDIA_PLAYING : X_EVENT_MEDIA_WAITING; //case 'play' : // 再生が開始された。play()メソッドからの復帰後に発生する場合に発生 //case 'pause' : // 再生が一時停止された。pauseメソッドからの復帰後に発生する場合に発生 @@ -444,16 +452,18 @@ if( X_Audio_constructor ){ }, actualPause : function(){ + var raw = this[ '_rawObject' ]; + console.log( '[HTMLAudio] pause' ); this.seekTime = this.getActualCurrentTime(); delete this._currentFixStart; - !this[ '_rawObject' ].error && this[ '_rawObject' ].pause(); + !raw.error && raw.pause(); if( X_HTMLAudio_pauseFix ){ - this[ '_rawObject' ].src = ''; + raw.src = ''; if( X_HTMLAudio_durationFix ){ delete this._durationFixPhase; delete this._durationFixSkip; diff --git a/0.6.x/js/07_audio/10_XAudioSprite.js b/0.6.x/js/07_audio/10_XAudioSprite.js index 6d4cdbb..85f9511 100644 --- a/0.6.x/js/07_audio/10_XAudioSprite.js +++ b/0.6.x/js/07_audio/10_XAudioSprite.js @@ -4,13 +4,13 @@ * Mobile Opera11 は Audio をサポートするがイベントが取れない * iframe 内で生成して、Audio Sprite の preset で再生できないか? */ -var X_AudioSprite_shouldUse = X_HTMLAudio && ( X_UA[ 'iOS' ] || X_UA[ 'AOSP' ] || X_UA[ 'OperaMobile' ] || X_UA[ 'OperaTablet' ] ), // Flash がない - X_AudioSprite_useVideoForMulti = //( 3.1 <= X_UA[ 'AOSP' ] < 4 ) || +var X_AudioSprite_shouldUse = X_HTMLAudio && ( X_UA[ 'iOS' ] || X_UA[ 'AOSP' ] || X_UA[ 'OperaMobile' ] || X_UA[ 'OperaTablet' ] ), // Flash がない + X_AudioSprite_useVideoForMulti = //( 3.1 <= X_UA[ 'AOSP' ] < 4 ) || //( ( 4.2 <= X_UA[ 'AOSP' ] ), // ドスパラパッドはビデオのインライン再生が不可 false, X_AudioSprite_disableMultiTrack = !X_WebAudio && ( X_UA[ 'iOS' ] || 4 <= X_UA[ 'AOSP' ] || X_UA[ 'ChromeWV' ] || ( X_UA[ 'WinPhone' ] && X_UA[ 'IE9' ] ) ), - X_AudioSprite_enableVolume = X_HTMLAudio && ( !X_UA[ 'iOS' ] && !X_UA[ 'AOSP' ] && !X_UA[ 'OperaMobile' ] && !X_UA[ 'OperaTablet' ] ), // TODO fennec は 25以上 + X_AudioSprite_enableVolume = X_HTMLAudio && ( !X_UA[ 'iOS' ] && !X_UA[ 'AOSP' ] && !X_UA[ 'OperaMobile' ] && !X_UA[ 'OperaTablet' ] ), // TODO fennec は 25以上 // http://tukumemo.com/html5-audio-sp/ // iOS6、Android4.1から同時再生が可能になりました。 X_AudioSprite_maxTracks = X_AudioSprite_useVideoForMulti ? 2 : X_AudioSprite_disableMultiTrack ? 1 : 9, @@ -405,6 +405,9 @@ function X_AudioSprite_backendHandler( e ){ case X_EVENT_READY : case X_EVENT_MEDIA_PLAYING : console.log( 'X.AudioSprite - Ready!' ); + for( i = 0; i < X_AudioSprite_TEMP.tracks.length; ++i ){ + X_AudioSprite_instance[ 'pause' ]( i ); + }; X_AudioSprite_instance[ 'asyncDispatch' ]( X_EVENT_READY ); break; };