成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

使用 CSS 漸變來實(shí)現(xiàn)波浪動(dòng)畫

開發(fā) 前端
這次嘗試一下使用 CSS 漸變來實(shí)現(xiàn)這樣一個(gè)效果,還可以用在文字背景上。

之前看到coco[1]的這樣一篇文章:純 CSS 實(shí)現(xiàn)波浪效果![2],非常巧妙,通過改變border-radius和不斷旋轉(zhuǎn)實(shí)現(xiàn)的波浪效果,有興趣的可以去研究一下。

圖片

這次嘗試一下使用 CSS 漸變來實(shí)現(xiàn)這樣一個(gè)效果,還可以用在文字背景上,如下:

圖片

不需要混合模式,花幾分鐘一起看看吧。

一、波浪的原理

首先可以分解一下波浪的原理,看似有點(diǎn)復(fù)雜,又是貝塞爾曲線,又是上下震動(dòng),其實(shí)都是視覺錯(cuò)覺,本質(zhì)上是一個(gè)水平方向的周期性運(yùn)動(dòng),曲線都是固定的,示意如下:

圖片

這下應(yīng)該能很直觀地觀察到動(dòng)畫的規(guī)律了,其實(shí)就是兩個(gè)半曲面,如下:

圖片

所以,問題就變成了,如何繪制兩個(gè)這樣的曲面?

二、曲面的繪制

提到曲面,可以想到徑向漸變,并且是橢圓的。

首先來看左邊這個(gè)曲面,其實(shí)就是一個(gè)透明到純色的徑向漸變,示意如下(可以想象成是一個(gè)透明的橢圓)。

圖片

用代碼實(shí)現(xiàn)就是。

div{
  background: radial-gradient(100% 57% at top ,#0000 100%,#2196F3 100.5%) no-repeat;
  background-size: 50% 100%;
  background-position: 0 100%;
  background-repeat: no-repeat;
}

為了自適應(yīng)容器,這里都采用的是百分比單位,效果如下:

圖片

用同樣的方式,可以繪制出又半部分,為了方便管理,可以用 CSS 變量來代替。

div{
  --c: #2196F3;
  --w1: radial-gradient(100% 57% at top ,#0000 100%,var(--c) 100.5%) no-repeat;
  --w2: radial-gradient(100% 57% at bottom,var(--c) 100%,#0000 100.5%) no-repeat;
  background: var(--w1),var(--w2);
  background-position: 0% 100%, 100% 100%;
  background-size: 50% 100%;
}

效果如下:

圖片

這個(gè)過程中,需要細(xì)微調(diào)整一下兩個(gè)曲面的位置關(guān)系,確保能夠完美的銜接在一起。

圖片

這樣,最關(guān)鍵的繪制就完成了。

三、波浪動(dòng)畫

最后就是動(dòng)畫了,其實(shí)就是一個(gè)重復(fù)水平運(yùn)動(dòng),在這里只需要改變background-position-x就行了。

不過需要注意的是,為了保證動(dòng)畫的連貫性,需要再“復(fù)制”一份完全相同的,避免在動(dòng)畫首尾處出現(xiàn)“空檔”,如下(為了方便顏色,暫時(shí)用不同的顏色代替)。

圖片

這時(shí),就體現(xiàn)出 CSS 變量的好處了,直接再寫兩個(gè)變量即可,如下:

div{
  --w1: radial-gradient(100% 57% at top ,#0000 100%,var(--c) 100.5%) no-repeat;
  --w2: radial-gradient(100% 57% at bottom, red 100%,#0000 100.5%) no-repeat;
  background: var(--w1),var(--w2),var(--w1),var(--w2); /*兩份*/
  background-position: -200% 100%, -100% 100%, 0% 100%, 100% 100%;
  background-size: 50% 100%;
  animation: m 1s infinite linear; /*無限循環(huán)動(dòng)畫*/
}

然后是動(dòng)畫關(guān)鍵幀,改變background-position-x即可。

@keyframes m {
  0%  {background-position-x:-200%, -100%, 0%, 100%}
  100%{background-position-x:  0%, 100%, 200%, 300%}
}

這樣就得到了一個(gè)水平方向不斷位移的動(dòng)畫。

圖片

將顏色都改成相同后,由于看不清左右的運(yùn)動(dòng),只能看到上下在晃動(dòng),就感覺非常像一個(gè)波浪了。

圖片

下面是完整代碼,是不是非常少?

.wave{
  width: 400px;
  height: 200px;
  outline: 2px dashed gray;
  --c: #2196F3;
  --w1: radial-gradient(100% 57% at top ,#0000 100%,var(--c) 100.5%) no-repeat;
  --w2: radial-gradient(100% 57% at bottom, var(--c) 100%,#0000 100.5%) no-repeat;
  background: var(--w1),var(--w2),var(--w1),var(--w2);
  background-position-x: -200%, -100%, 0%, 100%;
  background-position-y: 100%;
  background-size: 50.5% 100%;
  animation: m 1s infinite linear;
}
@keyframes m {
  0%  {background-position-x:-200%, -100%, 0%, 100%}
  100%{background-position-x:  0%, 100%, 200%, 300%}
}

你也可以訪問以下任意鏈接:

  • CSS gradient wave (juejin.cn)[3]
  • CSS gradient wave (codepen.io)[4]
  • CSS gradient wave (runjs.work)[5]

四、文字波浪動(dòng)畫

相比于其他實(shí)現(xiàn),漸變的最大優(yōu)勢(shì)是不占用任何標(biāo)簽,包括偽元素,這樣即使在非常苛刻的情況下也能使用,比如文章開頭的文字波浪效果

圖片

由于只是背景,直接像普通的漸變文字那樣使用就行了,完整代碼如下:

.txt{
  --c: #2196F3;
  --w1: radial-gradient(100% 57% at top ,#0000 100%,var(--c) 100.5%) no-repeat;
  --w2: radial-gradient(100% 57% at bottom, var(--c) 100%,#0000 100.5%) no-repeat;
  background: var(--w1),var(--w2),var(--w1),var(--w2);
  background-position-x: -200%, -100%, 0%, 100%;
  background-position-y: 100%;
  background-size: 50.5% 100%;
  animation: m 1s infinite linear;
  font-size: 100px;
  font-weight: bold;
  color: transparent;
  -webkit-background-clip: text; /*文本裁切*/
  -webkit-text-stroke: 2px var(--c);
}
@keyframes m {
  0%  {background-position-x:-200%, -100%, 0%, 100%}
  100%{background-position-x:  0%, 100%, 200%, 300%}
}

之前在這篇文章:CSS & SVG foreignObject 實(shí)現(xiàn)文字鏤空波浪動(dòng)畫[6]中用到了 SVG foreignObject實(shí)現(xiàn)的,有興趣的可以回顧一下。

你也可以訪問以下任意鏈接:

  • CSS gradient wave text (juejin.cn)[7]
  • CSS gradient wave text (codepen.io)[8]
  • CSS gradient wave text (runjs.work)[9]

五、總結(jié)一下

以上就是全部內(nèi)容了,相信實(shí)現(xiàn)起來沒有太多的難點(diǎn),主要就是徑向漸變的運(yùn)用,下面總結(jié)一下

  1. 波浪的本質(zhì)上是一個(gè)曲面在水平方向的周期性運(yùn)動(dòng),曲面本身并沒有變化。
  2. 波浪可以拆分為兩個(gè)不同方向上的徑向漸變。
  3. 特別需要注意漸變的尺寸和位置,確保能夠完美的銜接在一起。
  4. 動(dòng)畫其實(shí)就是不斷改變漸變的水平位置,也就是 background-position-x。
  5. 相比于其他實(shí)現(xiàn),漸變的最大優(yōu)勢(shì)是不占用任何標(biāo)簽。
  6. 還可以輕易的實(shí)現(xiàn)文字波浪效果。

一般同樣的效果我都會(huì)盡量用多種方式去實(shí)現(xiàn),每種方式都有各自不同的優(yōu)缺點(diǎn),以便于應(yīng)對(duì)各自不同的應(yīng)用場(chǎng)景。

參考資料

[1]coco: https://juejin.cn/user/2330620350437678。

[2]純 CSS 實(shí)現(xiàn)波浪效果!: https://juejin.cn/post/6844903487705186317。

[3]CSS gradient wave (juejin.cn): https://code.juejin.cn/pen/7239632409237880892。

[4]CSS gradient wave (codepen.io): https://codepen.io/xboxyan/pen/xxyoyPK。

[5]CSS gradient wave (runjs.work): https://runjs.work/projects/1a6b73b0ce224ee1。

[6]CSS & SVG foreignObject 實(shí)現(xiàn)文字鏤空波浪動(dòng)畫: https://juejin.cn/post/7069611855513124895。

[7]CSS gradient wave text (juejin.cn): https://code.juejin.cn/pen/7239663677074243588。

[8]CSS gradient wave text (codepen.io): https://codepen.io/xboxyan/pen/PoyrXdP。

[9]CSS gradient wave text (runjs.work): https://runjs.work/projects/8336f8017a0a449f。

責(zé)任編輯:姜華 來源: 前端偵探
相關(guān)推薦

2023-08-28 17:03:41

CSS 漸變線性漸變

2021-09-28 08:26:06

CSS 技巧文字鏤空波浪

2021-02-09 07:26:38

前端css技術(shù)熱點(diǎn)

2022-03-28 08:44:15

css3水波動(dòng)畫

2025-05-13 00:00:05

2022-09-12 08:31:41

CSS3偽類URI

2022-08-29 17:39:53

應(yīng)用開發(fā)css動(dòng)畫

2017-04-27 14:05:59

CSS動(dòng)畫前端

2021-05-18 06:22:39

CSS 制作波浪技巧

2021-11-15 07:45:06

CSS 技巧背景光動(dòng)畫

2023-06-27 09:33:15

Loading 動(dòng)畫CSS

2022-01-13 07:04:54

CSS 技巧Loading 動(dòng)畫

2023-05-08 09:08:33

CSS前端

2021-05-11 08:19:00

CSS 文字動(dòng)畫技巧

2021-09-08 22:28:13

前端Css3動(dòng)畫

2020-12-19 16:10:29

區(qū)塊鏈數(shù)字貨幣金融

2024-01-22 09:28:23

CSS前端滾動(dòng)驅(qū)動(dòng)

2022-01-28 09:01:49

架構(gòu)

2022-02-16 08:21:28

CSS三角邊框動(dòng)畫SVG

2020-12-24 08:37:41

Css前端加載動(dòng)畫
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 免费一级毛片 | 天天爽夜夜操 | 欧美一级欧美三级在线观看 | 久久精品女人天堂av | 久久久久亚洲精品国产 | 欧美a在线 | 夜夜草 | 97在线观视频免费观看 | 91精品国产91综合久久蜜臀 | 一级日批片 | 国产精品久久久久久妇女6080 | 蜜桃日韩 | 国产精品小视频在线观看 | 欧美日韩一区二区电影 | 狠狠操狠狠干 | 国产黄色在线观看 | 日本久久久久久 | 在线观看av网站永久 | 97精品视频在线观看 | 狠狠操狠狠搞 | 国产目拍亚洲精品99久久精品 | a级在线免费| 成人在线免费网站 | 久久久.com | 日日操av| 日本免费黄色一级片 | 亚洲午夜av久久乱码 | 色一情一乱一伦一区二区三区 | 综合久久亚洲 | av看片| 欧美激情一区二区三级高清视频 | 久久一二| 日本小电影在线 | 一区精品在线观看 | 一级黄色片免费在线观看 | 国产精品一区二区不卡 | 欧美一级淫片免费视频黄 | 伦理二区 | 日韩在线中文 | 在线色 | 欧美在线小视频 |