X_UA[ 'webOS' ] = true; // webOS\r
} else\r
if( sys.indexOf( 'Win' ) + 1 ){\r
- console.log( 'Win' );\r
- /**\r
- * @alias X.UA.Windows\r
- * @type {boolean}\r
- */\r
- X_UA[ 'Windows' ] = true;\r
+\r
switch( sys ){\r
+ case 'WinCE' :\r
+ /**\r
+ * @alias X.UA.WinCE\r
+ * @type {boolean}\r
+ */\r
+ X_UA[ sys ] = true;\r
+ break;\r
case 'Win16' :\r
case 'Win32' :\r
case 'Win64' :\r
- case 'WinCE' :\r
/**\r
* @alias X.UA.Win16\r
* @alias X.UA.Win32\r
* @alias X.UA.Win64\r
- * @alias X.UA.WinCE\r
* @type {boolean}\r
*/\r
X_UA[ sys ] = true;\r
+ \r
+ if( v = dav.split( 'Windows NT 10' )[ 1 ] ){\r
+ switch( v.substr( 0, 2 ) ){\r
+ case '.0' : v = 10; break;\r
+ default : v = '?';\r
+ };\r
+ } else\r
+ if( v = dav.split( 'Windows NT ' )[ 1 ] ){\r
+ switch( v.substr( 0, 3 ) ){\r
+ case '6.3' : v = 8.1; break;\r
+ case '6.2' : v = 8; break;\r
+ case '6.1' : v = 7; break;\r
+ case '6.0' : v = 'Vista'; break;\r
+ case '5.2' : v = '2003|XP64'; break;\r
+ case '5.1' : v = v.indexOf( '5.1; SV1' ) ? 'XP' : 'XPSP2'; break;\r
+ case '5.0' : v = v.indexOf( '5.01' ) ? 2000 : '2kSP1'; break;\r
+ case '4.0' : v = 'NT'; break;\r
+ default : v = '?';\r
+ }; \r
+ } else\r
+ if( v = dav.split( 'Windows ' )[ 1 ] ){\r
+ switch( v.substr( 0, 2 ) ){\r
+ case '98' : v = v.indexOf( '98; Win 9x 4.90' ) ? '98|98SE' : 'ME'; break;\r
+ case '95' : v = 95; break;\r
+ case '3.' : v = parseFloat( v ); break;\r
+ default : v = '?';\r
+ }; \r
+ } else {\r
+ v = '?';\r
+ };\r
+ \r
+ /**\r
+ * 10, 8.1, 8, 7, Vista, 2003|XP64, XPSP2, XP, 2kSP1, 2000, ME, 98|98SE, 95, ?\r
+ * @alias X.UA.Windows\r
+ * @type {number|string}\r
+ */ \r
+ X_UA[ 'Windows' ] = v;\r
+ break;\r
};\r
+\r
// winRT\r
} else\r
if( sys.indexOf( 'Mac' ) + 1 ){\r
*/\r
X_UA[ 'Linux' ] = true;\r
\r
- if( ( i = dua.indexOf( 'Android' ) ) !== -1 ){\r
+ if( dua.indexOf( 'Android ' ) !== -1 ){\r
+ v = dua.split( 'Android ' )[ 1 ].split( '.' );\r
+ /**\r
+ * @alias X.UA.AndroidMajor\r
+ * @type {number}\r
+ */\r
+ X_UA[ 'AndroidMajor' ] = parseFloat( v[ 0 ] ) || 0;\r
+ /**\r
+ * @alias X.UA.AndroidMinor\r
+ * @type {number}\r
+ */\r
+ X_UA[ 'AndroidMinor' ] = parseFloat( v[ 1 ] ) || 0;\r
+ /**\r
+ * @alias X.UA.AndroidPatch\r
+ * @type {number}\r
+ */\r
+ X_UA[ 'AndroidPatch' ] = parseFloat( v[ 2 ] ) || 0;\r
/**\r
* Firefox で Version が取れない!\r
* http://bizmakoto.jp/bizid/articles/1207/31/news004.html\r
* @alias X.UA.Android\r
* @type {number}\r
*/\r
- X_UA[ 'Android' ] = parseFloat( dua.substr( i + 8 ) ) || 0.1;\r
+ X_UA[ 'Android' ] = X_UA[ 'AndroidMajor' ] + X_UA[ 'AndroidMinor' ] / 10;\r
console.log( '>> Android : ' + X_UA[ 'Android' ] );\r
};\r
};\r
console.log( '>> Gecko : ' + X_UA[ 'Gecko' ] );\r
};\r
\r
- // TODO Blink\r
- if( window.chrome ){\r
- /**\r
- * @alias X.UA.Blink\r
- * @type {number}\r
- */\r
- X_UA[ 'Blink' ] = tv;\r
- console.log( '>>Blink : ' + X_UA[ 'Blink' ] );\r
- \r
- } else\r
- if( dav.indexOf( 'Konqueror' ) !== -1 ){\r
- /**\r
- * @alias X.UA.Khtml\r
- * @type {number}\r
- */\r
- X_UA[ 'Khtml' ] = tv;\r
- console.log( '>>Khtml : ' + X_UA[ 'Khtml' ] );\r
- \r
- } else\r
- if( ( i = dua.indexOf( 'Android ' ) ) !== -1 ){\r
+ if( ( dua.indexOf( 'Linux; U; Android ' ) !== -1 || dua.indexOf( 'Linux; Android ' ) !== -1 ) &&\r
+ ( dua.indexOf( 'Chrome\/' ) === -1 || dua.indexOf( 'Version\/' ) !== -1 ) ){ // Chrome/ を含まない または Version/ を含む\r
/**\r
* Android 標準ブラウザ\r
* @alias X.UA.AndroidBrowser\r
* @type {number}\r
*/\r
- X_UA[ 'AndroidBrowser' ] = i = parseFloat( dua.substr( i + 8 ) ) || 0.1;\r
+ X_UA[ 'AndroidBrowser' ] = X_UA[ 'Android' ];\r
+ \r
+ v = X_UA[ 'AndroidMajor' ];\r
+ \r
/**\r
* @alias X.UA.AndroidBrowser1\r
* @type {boolean}\r
*/\r
- X_UA[ 'AndroidBrowser1' ] = 1 <= i && i < 2;\r
+ X_UA[ 'AndroidBrowser1' ] = v === 1;\r
/**\r
* @alias X.UA.AndroidBrowser2\r
* @type {boolean}\r
*/\r
- X_UA[ 'AndroidBrowser2' ] = 2 <= i && i < 3;\r
+ X_UA[ 'AndroidBrowser2' ] = v === 2;\r
/**\r
* @alias X.UA.AndroidBrowser3\r
* @type {boolean}\r
*/\r
- X_UA[ 'AndroidBrowser3' ] = 3 <= i && i < 4;\r
+ X_UA[ 'AndroidBrowser3' ] = v === 3;\r
/**\r
* @alias X.UA.AndroidBrowser4\r
* @type {boolean}\r
*/\r
- X_UA[ 'AndroidBrowser4' ] = 4 <= i && i < 5;\r
+ X_UA[ 'AndroidBrowser4' ] = v === 4;\r
/**\r
* @alias X.UA.AndroidBrowser5\r
* @type {boolean}\r
*/\r
- X_UA[ 'AndroidBrowser5' ] = 5 <= i && i < 6;\r
+ X_UA[ 'AndroidBrowser5' ] = v === 5;\r
+ \r
console.log( '>> AndroidBrowser : ' + X_UA[ 'Android' ] );\r
\r
i = parseFloat(dua.split('WebKit\/')[1]);\r
* @type {number}\r
*/\r
X_UA[ 'AndroidWebkit' ] = i;\r
- alert( 'AudioSprite調査:Android標準ブラウザ Webkit Version ' + i );\r
+ //alert( 'AudioSprite調査:Android標準ブラウザ Webkit Version ' + i );\r
+ \r
+ if( window.chrome ){\r
+ //X_UA[ 'Blink' ] = X_UA[ 'AndroidChromeBrowser' ] = tv;\r
+ } else\r
+ if( v = parseFloat(dua.split('Chrome\/')[1]) ){\r
+ X_UA[ 'Chrome' ] = X_UA[ 'AndroidChromeBrowser' ] = v;\r
+ };\r
\r
+ //if( window[ 'webkitRequestFileSystem' ] ) alert( 'requestFileSystem' );\r
+ \r
+ //alert( 'html.style.WebkitAppearance:' + ( document.documentElement.style[ 'WebkitAppearance' ] === undefined ) + ' win.chrome:' + !!( window.chrome ) );\r
+\r
} else\r
+ \r
+ // TODO Blink\r
+ if( window.chrome ){ // Android3.1 の標準ブラウザで .chrome がいた、、、\r
+ /**\r
+ * @alias X.UA.Blink\r
+ * @type {number}\r
+ */\r
+ X_UA[ 'Blink' ] = tv;\r
+ console.log( '>>Blink : ' + X_UA[ 'Blink' ] );\r
+ \r
+ } else\r
+ if( dav.indexOf( 'Konqueror' ) !== -1 ){\r
+ /**\r
+ * @alias X.UA.Khtml\r
+ * @type {number}\r
+ */\r
+ X_UA[ 'Khtml' ] = tv;\r
+ console.log( '>>Khtml : ' + X_UA[ 'Khtml' ] );\r
+ \r
+ } else\r
+ \r
if( i = parseFloat(dua.split('WebKit\/')[1]) ){\r
/**\r
* @alias X.UA.WebKit\r