リビジョン | 512e08f4d38eab417f9651277e8a50c08535cb07 (tree) |
---|---|
日時 | 2016-02-10 16:56:24 |
作者 | itozyun <itozyun@user...> |
コミッター | itozyun |
Version 0.6.210, add Android browser PC mode detection.
@@ -17,7 +17,7 @@ var X_UA = X[ 'UA' ] = {}, | ||
17 | 17 | dav = navigator.appVersion, |
18 | 18 | tv = parseFloat(dav), |
19 | 19 | sys = navigator.platform, |
20 | - tridentToVer, i, j, v; | |
20 | + tridentToVer, i, j, v, androidBrowserPCMode; | |
21 | 21 | |
22 | 22 | console.log( ' userAgent : ' + dua ); |
23 | 23 | console.log( '-' ); |
@@ -233,9 +233,8 @@ var X_UA = X[ 'UA' ] = {}, | ||
233 | 233 | * @alias X.UA.Linux |
234 | 234 | * @type {boolean} |
235 | 235 | */ |
236 | - X_UA[ 'Linux' ] = true; | |
237 | - | |
238 | - if( v = dua.split( 'Android ' )[ 1 ] ){ | |
236 | + if( ( v = dua.split( 'Android ' )[ 1 ] ) || | |
237 | + ( v = sys.split( 'Android ' )[ 1 ] ) ){ // PCモードの Android Firefox では platform に Android 0.0.0 が存在 | |
239 | 238 | v = v.split( '.' ); |
240 | 239 | /** |
241 | 240 | * @alias X.UA.AndroidMajor |
@@ -265,6 +264,30 @@ var X_UA = X[ 'UA' ] = {}, | ||
265 | 264 | */ |
266 | 265 | X_UA[ 'Android' ] = X_UA[ 'AndroidMajor' ] + X_UA[ 'AndroidMinor' ] / 10; |
267 | 266 | console.log( '>> Android : ' + X_UA[ 'Android' ] ); |
267 | + } else | |
268 | + if( ( sys === 'Linux armv7l' || sys === 'Linux i686' ) && window.ontouchstart !== undefined && ( v = parseFloat( dua.split( 'WebKit\/' )[ 1 ] ) ) ){ | |
269 | + // https://ja.wikipedia.org/wiki/WebKit | |
270 | + // http://www.au.kddi.com/developer/android/kishu/ua/ | |
271 | + // webkit version to Android version... | |
272 | + androidBrowserPCMode = !window.chrome || v < 534.3; // 4.0 & 3.x には chrome がいる... | |
273 | + v = | |
274 | + v < 529 ? 1.5 : // <= 528.5 | |
275 | + v < 531 ? 2.0 : // 530 2.0~2.1 | |
276 | + // 533 2.2~2.3 | |
277 | + v < 534 ? ( window.HTMLAudioElement ? 2.3 : 2.2 ) : | |
278 | + v < 534.3 ? ( | |
279 | + !navigator[ 'connection' ] ? 4.4 : | |
280 | + document.execCommand && window.history && history.pushState ? 4.2/* & 4.3 */ : // ここに 4.1, 4.0 も入ってくる... | |
281 | + document.execCommand ? 4.1 : | |
282 | + window[ 'Int8Array' ] ? 4 : 3 ) : // 534 - 3.x~4.x , 534.13=3.x | |
283 | + v < 535 ? 4.0 : // 534.30 = 4.0-4.1 | |
284 | + v < 536 ? 4.1 : // 535.19 = 4.1 | |
285 | + v < 538 ? 4.4 : 0;// 537.36 = 4.4.2-5.x | |
286 | + if( v ){ | |
287 | + // PC版で見る、にチェックが付いている場合、ユーザーエージェント文字列にも platform にも Android の文字列が存在しない(標準ブラウザ&Chrome) | |
288 | + // Audio でタッチが必要か?の判定にとても困る... | |
289 | + X_UA[ 'Android' ] = v; | |
290 | + }; | |
268 | 291 | }; |
269 | 292 | }; |
270 | 293 |
@@ -350,7 +373,7 @@ var X_UA = X[ 'UA' ] = {}, | ||
350 | 373 | * @alias X.UA.EdgeMobile |
351 | 374 | * @type {number} |
352 | 375 | */ |
353 | - X_UA[ 'EdgeMobile' ] = v; | |
376 | + X_UA[ 'EdgeMobile' ] = v; | |
354 | 377 | }; |
355 | 378 | |
356 | 379 | } else |
@@ -620,11 +643,11 @@ var X_UA = X[ 'UA' ] = {}, | ||
620 | 643 | } else |
621 | 644 | |
622 | 645 | // Android 標準ブラウザ AOSP と ChromeWeb View, Sブラウザがある |
623 | - if( ( v = X_UA[ 'Android' ] ) && ( dua.indexOf( 'Chrome\/' ) < 0 || 0 < dua.indexOf( 'Version\/' ) ) ){ // Chrome/ を含まない または Version/ を含む | |
646 | + if( ( v = X_UA[ 'Android' ] ) && ( dua.indexOf( 'Chrome\/' ) < 0 || 0 < dua.indexOf( 'Version\/' ) || androidBrowserPCMode ) ){ // Chrome/ を含まない または Version/ を含む | |
624 | 647 | |
625 | 648 | /* if( window.chrome ){ // Android3.1 のAOSPブラウザで .chrome がいた、、、 |
626 | 649 | } else */ |
627 | - if( dua.indexOf( 'Version\/' ) < 0 && 0 < dua.indexOf( 'Chrome\/' ) ){ | |
650 | + if( dua.indexOf( 'Version\/' ) < 0 && 0 < dua.indexOf( 'Chrome\/' ) && !androidBrowserPCMode ){ | |
628 | 651 | /** |
629 | 652 | * Android 標準ブラウザ Chrome WebView ブラウザ |
630 | 653 | * @alias X.UA.ChromeWV |
@@ -3,6 +3,33 @@ | ||
3 | 3 | // ------------ local variables -------------------------------------------- // |
4 | 4 | // ------------------------------------------------------------------------- // |
5 | 5 | var X_String_CRLF = String.fromCharCode( 13 ) + String.fromCharCode( 10 ); |
6 | + X_String_CHAR_REFS = {"¡":161,"¢":162,"£":163,"¤":164,"¥":165,"¦":166,"§":167,"¨":168,"©":169, | |
7 | +"ª":170,"«":171, | |
8 | +"¬":172,"­":173,"®":174,"¯":175,"°":176,"±":177,"²":178,"³":179,"´":180,"µ":181,"¶":182, | |
9 | +"·":183,"¸":184,"¹":185,"º":186,"»":187,"¼":188,"½":189,"¾":190,"¿":191,"À":192, | |
10 | +"Á":193,"Â":194,"Ã":195,"Ä":196,"Å":197,"Æ":198,"Ç":199,"È":200,"É":201,"Ê":202, | |
11 | +"Ë":203,"Ì":204,"Í":205,"Î":206,"Ï":207,"Ð":208,"Ñ":209,"Ò":210,"Ó":211,"Ô":212, | |
12 | +"Õ":213,"Ö":214,"×":215,"Ø":216,"Ù":217,"Ú":218,"Û":219,"Ü":220,"Ý":221,"Þ":222, | |
13 | +"ß":223,"à":224,"á":225,"â":226,"ã":227,"ä":228,"å":229,"æ":230,"ç":231,"è":232, | |
14 | +"é":233,"ê":234,"ë":235,"ì":236,"í":237,"î":238,"ï":239,"ð":240,"ñ":241,"ò":242, | |
15 | +"ó":243,"ô":244,"õ":245,"ö":246,"÷":247,"ø":248,"ù":249,"ú":250,"û":251,"ü":252, | |
16 | +"ý":253,"þ":254,"ÿ":255,"Œ":338,"œ":339,"Š":352,"š":353,"Ÿ":376,"ˆ":710,"˜":732,"ƒ":402, | |
17 | +"Α":913,"Β":914,"Γ":915,"Δ":916,"Ε":917,"Ζ":918,"Η":919,"Θ":920,"Ι":921,"Κ":922,"Λ":923, | |
18 | +"Μ":924,"Ν":925,"Ξ":926,"Ο":927,"Π":928,"Ρ":929,"Σ":931,"Τ":932,"Υ":933,"Φ":934,"Χ":935,"Ψ":936, | |
19 | +"Ω":937,"α":945,"β":946,"γ":947,"δ":948,"ε":949,"ζ":950,"η":951,"θ":952,"ι":953,"κ":954, | |
20 | +"λ":955,"μ":956,"ν":957,"ξ":958,"ο":959,"π":960,"ρ":961,"ς":962,"σ":963,"τ":964,"υ":965,"φ":966, | |
21 | +"χ":967,"ψ":968,"ω":969,"ϑ":977,"ϒ":978,"ϖ":982," ":8194," ":8195," ":8201,"‌":8204,"‍":8205, | |
22 | +"‎":8206,"‏":8207,"–":8211,"—":8212,"‘":8216,"’":8217,"‚":8218,"“":8220,"”":8221,"„":8222, | |
23 | +"†":8224,"‡":8225,"•":8226,"…":8230,"‰":8240,"′":8242,"″":8243,"‹":8249,"›":8250,"‾":8254, | |
24 | +"⁄":8260,"€":8364,"ℑ":8465,"&ewierp;":8472,"ℜ":8476,"™":8482,"ℵ":8501,"←":8592,"↑":8593,"→":8594, | |
25 | +"↓":8595,"↔":8596,"↵":8629,"⇐":8656,"⇑":8657,"⇒":8658,"⇓":8659,"⇔":8660,"∀":8704,"∂":8706, | |
26 | +"∃":8707,"∅":8709,"∇":8711,"∈":8712,"∉":8713,"∋":8715,"∏":8719,"∑":8721,"−":8722,"∗":8727, | |
27 | +"√":8730,"∝":8733,"∞":8734,"∠":8736,"∧":8743,"∨":8744,"∩":8745,"∪":8746,"∫":8747,"∴":8756,"∼":8764, | |
28 | +"≅":8773,"≈":8776,"≠":8800,"≡":8801,"≤":8804,"≥":8805, | |
29 | +"⊂":8834,"⊃":8835,"⊄":8836,"⊆":8838,"⊇":8839,"⊕":8853,"⊗":8855,"⊥":8869,"⋅":8901, | |
30 | +"⌈":8968,"⌉":8969,"⌊":8970,"⌋":8971,"⟨":9001,"⟩":9002,"◊":9674,"♠":9824,"♣":9827, | |
31 | +"♥":9829,"♦":9830 | |
32 | +}; | |
6 | 33 | |
7 | 34 | // ------------------------------------------------------------------------- // |
8 | 35 | // --- interface ----------------------------------------------------------- // |
@@ -131,14 +158,26 @@ function X_String_whiteSpaceToTag( text ){ | ||
131 | 158 | * @return {string} html文字列 |
132 | 159 | */ |
133 | 160 | function X_String_chrReferanceTo( str ){ |
161 | + var refs, i, l, ref; | |
162 | + | |
134 | 163 | if( str == null || str === '' ) return ''; |
135 | - return str.toString() | |
164 | + if( str.indexOf( '&' ) === -1 ) return str; | |
165 | + | |
166 | + str = str.toString() | |
136 | 167 | .split( '"' ).join( '"' ) |
137 | 168 | .split( ''' ).join( "'" ) |
138 | 169 | .split( '<' ).join( '<' ) |
139 | 170 | .split( '>' ).join( '>' ) |
140 | - .split( ' ' ).join( ' ' ) | |
141 | - .split( '&' ).join( '&' ); // last! | |
171 | + .split( ' ' ).join( ' ' ); | |
172 | + | |
173 | + if( str.indexOf( '&' ) === -1 ) return str; | |
174 | + | |
175 | + refs = X_String_CHAR_REFS; | |
176 | + for( k in refs ){ | |
177 | + str = str.split( k ).join( String.fromCharCode( refs[ k ] ) ); | |
178 | + }; | |
179 | + | |
180 | + return str.split( '&' ).join( '&' ); // last! | |
142 | 181 | }; |
143 | 182 | |
144 | 183 | /** |
@@ -1110,7 +1110,7 @@ function X_Node_html( html ){ | ||
1110 | 1110 | if( !this[ '_tag' ] ) return this[ 'text' ]( html ); |
1111 | 1111 | |
1112 | 1112 | this[ 'empty' ](); |
1113 | - if( html ){ | |
1113 | + if( html += '' ){ | |
1114 | 1114 | X_Node_append.apply( this, X_HtmlParser_parse( html, true ) ); |
1115 | 1115 | }; |
1116 | 1116 | return this; |