第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

章節(jié)
問答
課簽
筆記
評論
占位
占位

補(bǔ)充內(nèi)容雪碧圖的自適應(yīng)縮放

本節(jié)的內(nèi)容沒有在七夕主題效果中實(shí)現(xiàn),這是一個(gè)額外的知識點(diǎn),留給大家思考的一個(gè)問題:雪碧圖如何做自適應(yīng)縮放?

本課程采用了CSS3的動畫關(guān)鍵幀實(shí)現(xiàn)了精靈動畫,所有的精靈圖都是通過合成的雪碧圖獲取的,這樣帶來了一個(gè)根本問題:通過background-position獲取的圖片,正常情況下是無法縮放的,因?yàn)閳D片的位置是固定了,如果通過這種方式實(shí)現(xiàn)了精靈圖那么在不同的分辨率下其實(shí)都是固定的尺寸,這樣效果就明顯有點(diǎn)呆板了

針對這樣的問題,當(dāng)然也有折中的辦法,比如我們不加載精靈圖,而是通過background-image加載一張一張的圖片,這樣是可以的,但是需要預(yù)加載的處理,否則圖片大了會閃屏了。一般精靈圖都是通過position處理比較合理,我們有沒有辦法把這個(gè)圖片給縮放一下達(dá)到自適應(yīng)的目的呢?這里我給大家一個(gè)參考的方案,CSS3有一個(gè)scale可以這樣處理。

這里先參考下我右邊代碼的實(shí)現(xiàn)效果,人物是不是感覺縮放了?

縮放原理:

通過CSS3的scale處理直接可以讓元素縮放

需要處理的問題:

  • 需要計(jì)算出元素的縮放比,可以根據(jù)屏幕的寬度與UI的設(shè)計(jì)比例縮放

帶來的問題:

  • 通過scale縮放后瀏覽器認(rèn)為這個(gè)元素尺寸是沒變化的,所以要得到縮放后的尺寸算法應(yīng)該是 實(shí)際尺寸 * 縮放比
  • scale是默認(rèn)按照中間基點(diǎn)縮放,所以需要計(jì)算出實(shí)際布局與縮放后布局的一個(gè)內(nèi)部縮放距離,就是一個(gè)類似padding一樣的數(shù)據(jù)

具體的算法我右邊已經(jīng)給出來了

通過UI的設(shè)計(jì)與屏幕算一個(gè)縮放比

$(document).width() / 1440

通過這個(gè)縮放比,設(shè)置下元素的縮放大小,然后通過實(shí)際的人物尺寸與縮放比算出人物內(nèi)部縮放的數(shù)據(jù)boyInsideLeft與boyInsideTop

最終,要定為人物在中間位置的算法:

人物在馬路中間 = 馬路中間路的垂直距離 - 人物原始的垂直距離 - 人物縮放后的垂直距離

這樣算法我們可以弄一個(gè)公共方法出來,通過這樣的方式,我們可以很愉快的改造雪碧圖實(shí)現(xiàn)自適應(yīng)布局了~~~

PS: 我之后又仔細(xì)研究下雪碧圖的自適應(yīng)問題,想到一種比較完美的方案,具體可以參見我的博客:原創(chuàng):CSS3技術(shù)-雪碧圖自適應(yīng)縮放

 

任務(wù)

?不會了怎么辦
||

提問題

寫筆記

公開筆記
提交
||

請驗(yàn)證,完成請求

由于請求次數(shù)過多,請先驗(yàn)證,完成再次請求

加群二維碼

打開微信掃碼自動綁定

您還未綁定服務(wù)號

綁定后可得到

  • · 粉絲專屬優(yōu)惠福利
  • · 大咖直播交流干貨
  • · 課程更新,問題答復(fù)提醒
  • · 賬號支付安全提醒

收藏課程后,能更快找到我哦~

使用 Ctrl+D 可將課程添加到書簽

邀請您關(guān)注公眾號
關(guān)注后,及時(shí)獲悉本課程動態(tài)

舉報(bào)

0/150
提交
取消
全部 精華 我要發(fā)布
全部 我要發(fā)布
最熱 最新
只看我的

手記推薦

更多

本次提問將花費(fèi)2個(gè)積分

你的積分不足,無法發(fā)表

為什么扣積分?

本次提問將花費(fèi)2個(gè)積分

繼續(xù)發(fā)表請點(diǎn)擊 "確定"

為什么扣積分?