web前端入門到實戰(zhàn):使用CSS實現(xiàn)圖片幀動畫與曲線運動-創(chuàng)新互聯(lián)

在前端開發(fā)中,提到動畫,我們可以:

左貢網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián)公司,左貢網(wǎng)站設(shè)計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為左貢上1000家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)營銷網(wǎng)站建設(shè)要多少錢,請找那個售后服務(wù)好的左貢做網(wǎng)站的公司定做!
  1. 直接利用DOM實現(xiàn)動畫。
  2. 利用canvas實現(xiàn)動畫。
  3. 利用svg實現(xiàn)動畫。
  4. 直接用一張gif動圖。
  5. 利用圖片實現(xiàn)幀動畫。
  6. ...

所有動畫的基本原理都是:在短時間內(nèi)連續(xù)依次展示對應(yīng)的圖片,這樣在視覺上看起來就是'動'的了。本文主要來說一說第4點和第5點。

圖片幀動畫

當(dāng)我們要實現(xiàn)的動畫效果比較復(fù)雜,而且開發(fā)排期比較緊的情況下,用一張gif動圖來實現(xiàn)動畫是成本最低,效果也不錯的一種方案。比如下面這種動畫效果:

web前端入門到實戰(zhàn):使用CSS實現(xiàn)圖片幀動畫與曲線運動

可是如果我們想讓動效在某個時候暫停,隔一段時間后,再從斷點開始繼續(xù)播放動效,用gif圖就實現(xiàn)不了了。gif圖的動效是沒有辦法暫停的。這個時候,可以考慮采用圖片幀動畫。

圖片幀動畫可以看做是:把gif圖的原理在前端用代碼實現(xiàn)了一遍。

上面?zhèn)€那個動效,(假設(shè))可以分成100幀,即100張圖片,然后用代碼控制100張圖片依次顯示。并且,可以隨時在中途暫停。為了節(jié)省http請求,把100張圖片合成一張雪碧圖,然后用background-position去控制顯示哪一張圖。推薦一個很不錯的圖片生成工具:GKA

我把100張圖片生成了一個豎直的雪碧圖。

web前端入門到實戰(zhàn):使用CSS實現(xiàn)圖片幀動畫與曲線運動

在代碼里,只需要更新DOM元素的background-position即可實現(xiàn)動畫。

首先第一個點需要注意:background-position設(shè)置的是背景圖片相對于DOM元素的起始位置。

假設(shè)DOM元素和圖片寬高都是 100 * 200

專門建立的學(xué)習(xí)Q-q-u-n⑦⑧④-⑦⑧③-零①②  分享學(xué)習(xí)方法和需要注意的小細(xì)節(jié),不停更新最新的教程和學(xué)習(xí)技巧(從零基礎(chǔ)開始到前端項目實戰(zhàn)教程,學(xué)習(xí)工具,全棧開發(fā)學(xué)習(xí)路線以及規(guī)劃)
--- css

#wrapper {
    width: 100px;
    height: 200px;
    background-image: url('雪碧圖.png');
    background-size: 100% 10000%; // 有100張圖, 100*100
    background-repeat: no-repeat;
}

--- js

var domEl = document.querySelector('#wrapper');
var n; // n:顯示雪碧圖中第幾張圖片,n >=0 && n<100
domEl.style.backgroundPosition = `0px ${-n*200}px`; // 注意這里是負(fù)值

我們只需要用js控制n的值就行,就可以很容易實現(xiàn)隨時執(zhí)行、暫停動效。

上面的例子中,dom元素寬高是固定的,如果不固定、想要自適應(yīng)的話,需要根據(jù)圖片寬高比,通過padding-top來設(shè)置dom元素的寬高比。這個時候,在background-position中,也無法使用具體的數(shù)值了,需要使用百分比。這里有一個需要注意的地方:

background-position百分比取值時,很自然的以為是直接用背景圖片寬高乘以百分比即可得到最終偏移量,但其實不是的。計算公式如下:

x偏移量 = (元素寬度—背景圖片的寬度)*x百分比
y偏移量 = (元素高度—背景圖片的高度)*y百分比

換算一下:

x百分比 = x偏移量 / (元素寬度 - 背景圖片寬度)
y百分比 = y偏移量 / (元素高度 - 背景圖片高度)

具體到上面的例子中,就是:

// 假設(shè)每一張小圖片寬度為w, 高度為h, 當(dāng)前需要展示第n張圖片,一共有100張圖,則
var xPercent = 0;
var yPercent = -hn / (h - 100h) * 100 =  n / 99 * 100;
domEl.style.backgroundPosition = `${xPercent}% ${yPercent}%`;

最終,我們就能實現(xiàn)圖片幀動畫了。當(dāng)然,如果不需要完全控制動畫效果,可以不借助js,直接用css即可?;蛘咧苯佑胓if動圖就好。

css曲線運動

曲線運動,使用svg,canvas是很不錯的選擇。但是在對曲線的路徑不那么嚴(yán)格要求的時候,使用svg和canvas或許略微麻煩了。可以直接用css來實現(xiàn)一個『看起來是曲線』的運動。

以類似拋物線的一個運動為例,大概是一個這樣的效果:

web前端入門到實戰(zhàn):使用CSS實現(xiàn)圖片幀動畫與曲線運動

位移曲線上某點的切線就是速度,而速度可以分解成x軸的速度和y軸的速度。也就是說,上面的運動可以分解成水平方向x軸的運動和豎直方向y軸的運動。從感官上,不難看出,x軸的運動大概是勻速的,而y軸的運動是越來越快的。

另外,由于運動分解成了兩個方向的運動,需要兩個DOM,分別寫動畫,才能實現(xiàn)最終的效果。

--- html

<div class='x-container'>
    <div class='y-container'></div>
</div>

--- css

.x-container {
    width: 50px;
    height: 50px;
    animation: xMove 2s linear;
}
.y-container {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background-color: #000;
    animation: yMove 2s cubic-bezier(.98,.03,.91,.77);
}
@keyframes xMove {
    0% {
    }
    100% {
      transform: translateX(400px);
    }
}
@keyframes yMove {
    0% {
    }
    100% {
      transform: translateY(400px);
    }
}

兩個方向的運動合起來,就是上面的效果了。

想要實現(xiàn)一個不那么嚴(yán)格的曲線運動,直接使用css animation,也是一個不錯的選擇。

寫在后面

本文總結(jié)了依賴css實現(xiàn)圖片幀動畫和曲線運動的實例。

分享標(biāo)題:web前端入門到實戰(zhàn):使用CSS實現(xiàn)圖片幀動畫與曲線運動-創(chuàng)新互聯(lián)
網(wǎng)站鏈接:http://bm7419.com/article4/dscioe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)、用戶體驗、網(wǎng)站內(nèi)鏈、微信小程序、軟件開發(fā)域名注冊

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司