html適配Anroid手機

本文全然是翻譯與總結谷歌官方的教程,已確保文檔的正確性。

免得大家被五花八門的其它的資料弄混了,也沒有系統行的學習。


一、設置窗體尺寸和適配屏幕分辨率

谷歌官方文檔提到兩個大的方面。

1.Viewport視圖窗體

這個是html中設置的。主要是設置高度和寬度,還有初始的比列。

這個寬度與高度將絕對html里面CSS中有多少個像素可用。

Viewport的寬度與屏幕的寬度沒有決定性的關系。比方你的手機寬度是480PX可是你能夠設置Viewport的寬度為960PX,這樣一張800PX的圖片就能一次性顯示完整。由于非常多瀏覽器比方chrome,會盡可能的縮放,縮小到能一屏幕能展現整個網頁,也就是960PX的寬度。

注意:使用webView時并不會默認使用 全局概要模式。

也就是自己主動縮小,用這種方法設置一下即可setUseWideViewPort().

<head><title>Example</title><meta name="viewport" content="width=device-width, user-scalable=no" />
</head>

<meta name="viewport"content="height = [pixel_value | "device-height"] ,width = [pixel_value | "device-width"] ,initial-scale = float_value ,minimum-scale = float_value ,maximum-scale = float_value ,user-scalable = ["yes" | "no"]" />
注意:除非你確定你的程序自己主動適配的非常好。并且在最小尺寸下也能使用,否則不要關閉user-scalable。

2.屏幕分辨率

html在CSS中寫的像素單位。在Android中等同于160DPI的手機。

假設是320DPI的手機,就會對這個單位進行放大。

比方假設一張300像素寬的圖片。在160PI中能正常的顯示。可是到了320DPI中的手機就會放大兩倍。這個時候圖片就會失真,模糊。有紋理。


二、通過CSS來適配

1.不同分辨率使用不同的CSS?

通過設置-webkit-device-pixel-ratio?這個屬性0.75,1,,1.5來相應低分率,中分辨率,高分辨率。事實上就是以下的寫法

<link rel="stylesheet" media="screen and (-webkit-device-pixel-ratio: 1.5)" href="hdpi.css" />
<link rel="stylesheet" media="screen and (-webkit-device-pixel-ratio: 1.0)" href="mdpi.css" />
2.或者通過不同的style和樣式表。寫法例如以下

#header {background:url(medium-density-image.png);
}@media screen and (-webkit-device-pixel-ratio: 1.5) {/* CSS for high-density screens */#header {background:url(high-density-image.png);}
}@media screen and (-webkit-device-pixel-ratio: 0.75) {/* CSS for low-density screens */#header {background:url(low-density-image.png);}
}
很多其它關于怎樣適配分辨率尤其是圖片的適配能夠參見?High DPI Images for Variable Pixel Densities.。

稍后假設有時間會把這個鏈接里面的內容也總結一下。

三、通過javascript來適配


寫法例如以下:

Android瀏覽器或者WebView會通過?window.devicePixelRatio這個DOM文檔定義的屬性來指定當前的縮放比例。

默認的縮放比例是1.0.能夠通過例如以下代碼來獲取比例,并作出相應的處理。

if (window.devicePixelRatio == 1.5) {alert("This is a high-density screen");
} else if (window.devicePixelRatio == 0.75) {alert("This is a low-density screen");
}

轉載于:https://www.cnblogs.com/zfyouxi/p/5137673.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/375164.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/375164.shtml
英文地址,請注明出處:http://en.pswp.cn/news/375164.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

算術運算與邏輯運算

邏輯運算又稱布爾運算,取值只有兩個真或假,二進制數1和0在邏輯上可以代表真與假,是與否 算術運算...小學就開始學的了 兩者的區別在與邏輯運算是按位進行的,位與位之間沒有進位或借位.邏輯加法(OR)OR OPRD1,OPRD2 ;OPRD1<--OPRD1 OPRD2 算術加法(ADD)ADD OPRD1,OPRD2 ;O…

Webpack 入門指迷--轉載(題葉)

最近看到這個東西&#xff0c;一頭霧水。看了一些資料了解了Webpack概念&#xff0c;大體是webpack 是一個模塊綁定器&#xff0c;主要目的是在瀏覽器上綁定 JavaScript 文件。 看到題葉寫的一篇介紹&#xff0c;寫的很好&#xff0c;轉載連接http://segmentfault.com/a/119000…

非操作指令NOT

否操作指令NOT(又稱邏輯非運算)01 ;非0等于110 ;非1等于0NOT OPRD ;該指令把操作數OPRD取反然后送回OPRDmov ah,11111111B ;FFHnot ah ;執行后AH0Hmov ah,11110000B ;F0Hnot ah ;執行后AH00001111B 0FH

jquery的動畫學習--jquery權威指南

前面的fadeIn和fadeOut還有fadeTo以及sildeToggle還有sildeUp\sildeDown還有toggle還有show、hide等都經常用&#xff0c;就不再手寫了&#xff0c;需要注意的是fadeTo的合理應用&#xff0c;可以規定opactiy的具體數值&#xff0c;另外各個效果的回調函數可以多用用。$("…

防止Button按鈕重復點擊

背景&#xff1a;在測試中&#xff0c;測試MM總喜歡連續重復點擊Button&#xff0c;如果click事件的處理業務&#xff0c;稍微有些耗時&#xff0c;或者設備反應比較慢時&#xff0c;就會響應2遍處理&#xff0c;導致錯誤的現象出現。 前提&#xff1a;click事件的處理業務&…

8086交換指令XCHG

XCHG OPRD1,OPRD2;實現OPRD1與OPRD2之間數據交換;OPRD1,OPRD2同時是字節或字操作數, MOV AX,1 MOV BX,2 XCHG AX,BX ;執行后AX2,BX1

[傅里葉變換及其應用學習筆記] 二十四. 級聯,脈沖響應

我們上節課學習了 在離散有限維空間中&#xff0c;任何線性系統都是通過矩陣間的相乘得到的在連續無限維空間中&#xff0c;任何線性系統都是通過對核函數的積分得到的脈沖響應&#xff08;impulse response&#xff09; 級聯線性系統&#xff08;Cascading linear system&…

WPF如何實現TreeView節點重命名

我們經常看到一些軟件比如酷狗音樂&#xff0c;在對列表右鍵進行重命名的時候&#xff0c;當前列表會泛白并且進入可編輯狀態&#xff0c;當我們更改完成后就會并進入非編輯狀態&#xff0c;這些具體是怎么實現的呢&#xff1f;下面的方法也許會提供一些思路&#xff0c;下面的…

8086地址傳送指令LEA

LEA REG,OPRD ;操作數OPRD必須是一個存儲器操作數 LEA AX,IDATA ;把IDATA的偏移地址傳送到AX寄存器中DATA SEGMENTIDATA DW 1,2,3,4 DATA ENDS CODE SEGEMNT BEG:MOV AX,OFFSET IDATA ;AXIDATA的偏移地址LEA AX,IDATA ;AXIDATA的偏移地址LEA AX,DS:[IDATA] ;把ds:[IDA…

Shell --- 批量修改文件后綴腳本

for f in *.$1; dofilenamebasename $fmv $f "${filename%.*}".$2; done; Usage:&#xff1a; rename suffix rename_suffix eg: rename dat txt > ls > a.dat > rename dat txt > ls > a.txt 轉載于:https://www.cnblogs.com/RookieCoder/p/5140265.…

8086標志操作指令

標號傳送指令LAHF 把FLAG低八位送入AH。不影響FLAG的任何位LAHF ;把CF,PF,AF,ZF,SF送入AH的相應位即0,2,4,6,7位SAHF 把AH送入FLAG低八位。根據AH中的內容FLAG的低八位受到影響,高位不受影響MOV AH,11111111B SAHF ;(執行后CF,PF,AF,ZF,SF等于1)PUSHF 把FLAG壓入棧中。不影…

最大子序列和

一、遍歷所有可能情況 (1234...N)所有可能子序列如下&#xff1a; 1&#xff1b;12&#xff1b;123...... 2&#xff1b;23&#xff1b;234...... ...... N 共N趟&#xff0c;沒趟可能的情況由N&#xff0c;N-1...&#xff0c;1依次遞減。 時間復雜度O(N3)的算法&#xff1a; i…

!--注釋--和%--注釋--%有什么區別

轉載&#xff1a;版權所有&#xff1a;基礎軟件。作者郵箱&#xff1a;s.j.l.studiohotmail.com&#xff0c;sun.j.l.studiogmail.com。本文首發于 http://www.cnblogs.com/FoundationSoft。文章轉載請保持此版權信息并注明出處。 使用ASP.NET編輯頁面時&#xff0c;有兩種注釋…

團隊開發——用戶需求調研報告

用戶需求調研報告 項目名稱&#xff1a; 躲避小球 項目編號&#xff1a;001 調研主題&#xff1a; 用戶需求 訪談時間&#xff1a;2015.4.10 調研地點&#xff1a; 石家莊鐵道大學圖書館 訪談部門&#xff1a; 三個人行 參與人員&#xff1a; 林彥汝 1. 訪談目的 1、讓用…

8086地址傳送指令LDS,LES

LDS REG,OPRE;REG是一個16位寄存器,OPRD是一個存儲器操作數,為雙字項,高16位送入DS,低16位送入REG LDS BX,[SI](ds:si取得存儲器中32位(雙字),高16位作為段值送入DS中,低十六位送入指定的BX寄存器中)data segmentidata dd 12345678H data ends code segment assume cs:code,ds:…

設計模式(十五):解釋器模式

一、定義 在設定環境中&#xff0c;定義一種規則或者語法&#xff0c;通過解釋器來解釋規則或者語法的含義. 二、實例&#xff1a;將 二十一 —> 21 2.1 設定我們的環境 Context public class Context{public string Input { get; set; }public int Output { get; se…

8086地址傳送指令LEA,LDS,LES

LEA BX,[SI] ;BX<--DS:[SI]內存單元的偏移地址,與該單元中的數據無關 LDS BX,[SI] ;BX<--DS:[si]內存單元中的數據的低16位,DS<--內存單元中數據的高16位 LES BX,[SI] ;BX<--DS:[SI] ,ES<--DS:[SI2] 顯然LDS和LES的操作數是32位的(兩個字 四個字節 32位) 寫個…

MySQL 5.7.10 免安裝配置

# 配置環境&#xff1a;windows 64bit # 安裝版本&#xff1a;mysql-5.7.10-win32&#xff08;zip archive版本&#xff09; 1. ZIP Archive版是免安裝的&#xff0c;只需把mysql-5.7.10-win32.zip解壓到安裝目錄即可。 2. 在D:\Program Files\mysql-5.7.10-win32文件夾下新建配…

Cacti安裝教程

CentOS 6.0架設流量監控及集中日志系統第一章、cacti的安裝1、 系統的基本設置2、 設置主機名3、 [rootlocalhost ~]# vi /etc/sysconfig/network4、 [rootlocalhost ~]# exit5、 重新登陸6、 [rootGZ-Cacti ~]#7、 安裝screen后臺運行程序yum -y install screen8、 安裝優秀的…

8086條件轉移指令JE,JZ

JZ/JE 指令格式 轉移條件 說明 JZ/JE 標號 ZF1 等于0或相等轉移code segment assume cs:codemov ax,2mov bx,2cmp ax,bxje ok ;如果axbx 進行轉移(其實是檢測ZF的值進行轉移操作);根據ZF1 得出axbx ,所以才有axbx 相等則轉移 iout: mov ax,4c00Hint 21H ok: add a…