OSDN Git Service

Version 0.6.181, fix X.UA & X.HTMLAudio & X.AudioSprite.
authoritozyun <itozyun@user.sourceforge.jp>
Thu, 22 Oct 2015 01:29:57 +0000 (10:29 +0900)
committeritozyun <itozyun@user.sourceforge.jp>
Thu, 22 Oct 2015 01:29:57 +0000 (10:29 +0900)
0.6.x/js/01_core/02_XUA.js
0.6.x/js/07_audio/02_XHTMLAudio.js
0.6.x/js/07_audio/10_XAudioSprite.js

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