国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

使用 CSS 漸變來實現波浪動畫

開發 前端
這次嘗試一下使用 CSS 漸變來實現這樣一個效果,還可以用在文字背景上。

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

圖片

這次嘗試一下使用 CSS 漸變來實現這樣一個效果,還可以用在文字背景上,如下:

圖片

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

一、波浪的原理

首先可以分解一下波浪的原理,看似有點復雜,又是貝塞爾曲線,又是上下震動,其實都是視覺錯覺,本質上是一個水平方向的周期性運動,曲線都是固定的,示意如下:

圖片

這下應該能很直觀地觀察到動畫的規律了,其實就是兩個半曲面,如下:

圖片

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

二、曲面的繪制

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

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

圖片

用代碼實現就是。

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;
}

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

圖片

用同樣的方式,可以繪制出又半部分,為了方便管理,可以用 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%;
}

效果如下:

圖片

這個過程中,需要細微調整一下兩個曲面的位置關系,確保能夠完美的銜接在一起。

圖片

這樣,最關鍵的繪制就完成了。

三、波浪動畫

最后就是動畫了,其實就是一個重復水平運動,在這里只需要改變background-position-x就行了。

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

圖片

這時,就體現出 CSS 變量的好處了,直接再寫兩個變量即可,如下:

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; /*無限循環動畫*/
}

然后是動畫關鍵幀,改變background-position-x即可。

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

這樣就得到了一個水平方向不斷位移的動畫。

圖片

將顏色都改成相同后,由于看不清左右的運動,只能看到上下在晃動,就感覺非常像一個波浪了。

圖片

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

.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]

四、文字波浪動畫

相比于其他實現,漸變的最大優勢是不占用任何標簽,包括偽元素,這樣即使在非??量痰那闆r下也能使用,比如文章開頭的文字波浪效果

圖片

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

.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 實現文字鏤空波浪動畫[6]中用到了 SVG foreignObject實現的,有興趣的可以回顧一下。

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

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

五、總結一下

以上就是全部內容了,相信實現起來沒有太多的難點,主要就是徑向漸變的運用,下面總結一下

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

一般同樣的效果我都會盡量用多種方式去實現,每種方式都有各自不同的優缺點,以便于應對各自不同的應用場景。

參考資料

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

[2]純 CSS 實現波浪效果!: 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 實現文字鏤空波浪動畫: 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。

責任編輯:姜華 來源: 前端偵探
相關推薦

2023-08-28 17:03:41

CSS 漸變線性漸變

2021-09-28 08:26:06

CSS 技巧文字鏤空波浪

2021-02-09 07:26:38

前端css技術熱點

2022-03-28 08:44:15

css3水波動畫

2025-05-13 00:00:05

2022-09-12 08:31:41

CSS3偽類URI

2022-08-29 17:39:53

應用開發css動畫

2017-04-27 14:05:59

CSS動畫前端

2021-05-18 06:22:39

CSS 制作波浪技巧

2021-11-15 07:45:06

CSS 技巧背景光動畫

2023-06-27 09:33:15

Loading 動畫CSS

2022-01-13 07:04:54

CSS 技巧Loading 動畫

2023-05-08 09:08:33

CSS前端

2021-05-11 08:19:00

CSS 文字動畫技巧

2021-09-08 22:28:13

前端Css3動畫

2024-01-22 09:28:23

CSS前端滾動驅動

2020-12-24 08:37:41

Css前端加載動畫

2022-01-28 09:01:49

架構

2022-02-16 08:21:28

CSS三角邊框動畫SVG

2022-08-29 15:19:09

CSS煙花動畫
點贊
收藏

51CTO技術棧公眾號

无码少妇一区二区三区芒果| 久久国产精品电影| 欧美午夜激情视频| 日韩av手机在线观看| 97av视频在线观看| 88xx成人网| 日本aⅴ精品一区二区三区 | 制服诱惑亚洲| 国产精品123| 欧美xxxx做受欧美| 中文字幕在线免费专区| 欧美久色视频| 午夜成人免费视频| 999在线免费视频| 精品自拍一区| 国产激情一区二区三区| 国产精品扒开腿做爽爽爽视频| 综合久久国产| www.久久ai| 日本欧美在线看| 欧美夫妻性生活视频| 亚洲做受高潮| 亚洲综合国产| 亚洲最新av在线网站| 95影院理论片在线观看| 激情综合一区二区三区| 国产精品高清在线观看| 中文字幕网在线| 美女日批免费视频| 久久久久久久久成人| 亚洲va在线va天堂| 日韩精品视频在线看| 北岛玲一区二区三区四区| 成人精品水蜜桃| 国产高清一区| 欧美亚洲国产视频小说| 免费一级欧美在线观看视频| 在线综合视频播放| 中文产幕区在线观看| 亚洲国产欧美日韩另类综合 | 免费成人毛片| 亚洲精品色婷婷福利天堂| 久久视频免费在线| 中文字幕免费精品| 欧美日韩精品系列| 久久久欧美精品| 尤物视频在线观看| 在线日韩一区二区| 丰满少妇在线观看| 久久人人超碰| 国产精品高清网站| 91久久青草| 欧美一区二区久久久| www.日本在线播放| 欧美经典三级视频一区二区三区| 超碰97人人人人人蜜桃| 国产欧美日本一区视频| 你懂的国产精品永久在线| 免费观看黄色网| 亚洲熟妇无码一区二区三区导航| 亚洲国产综合在线| 亚洲精品一区二区三区中文字幕| 蜜桃臀一区二区三区| 天天综合天天做天天综合| 日韩成人一级| 国产精品影片在线观看| 色先锋资源久久综合| 免费成人在线观看| 日韩中文影院| 成人中心免费视频| 亚洲午夜免费视频| 中文乱码免费一区二区| 久久国产人妖系列| 不卡在线一区二区| 青青草手机在线| 亚洲一区二区在线免费观看| 国产亚洲精品高潮| 中文字幕欧美激情一区| 亚洲无中文字幕| 中文字幕一区二区三区四区在线视频| 在线电影中文日韩| 久久精品国产在热久久| 国产综合激情| 精品国精品国产自在久国产应用| 最新天堂资源在线| 欧美日韩综合久久| 亚洲乱码一区二区| 欧美挠脚心视频网站| 久久久久久久久久久久久夜| 97精品视频| 夜鲁夜鲁夜鲁视频在线播放| 中文字幕 91| 黄色一级视频网站| 黄色毛片av| 亚洲性生活网站| 91在线观看免费高清| 欧美精品久久久久久久久老牛影院| 麻豆一区二区在线| 欧美精品国产一区二区| 天堂中文最新版在线中文| 蜜臀在线观看| 亚洲欧美日韩一级| 亚洲国产日韩欧美在线| 色猫猫国产区一区二在线视频| 亚洲人亚洲人成电影网站色| 香蕉视频一区| 色黄视频在线观看| 大香伊人久久| 中文字幕在线直播| 国产乱码精品一区二区三区亚洲人 | 欧美在线视频二区| 黑人与亚洲人色ⅹvideos| 黄页在线观看视频| 秋霞午夜在线观看| 成人香蕉视频| 日韩高清国产一区在线| 国产真实乱子伦精品视频| 亚洲天堂免费在线观看视频| 91精品国产欧美日韩| 99精品久久只有精品| 婷婷综合网站| 久久精品亚洲成在人线av网址| 久久久久久三级| 最新亚洲伊人网| 成a人片在线观看| 在线观看三级视频| 亚洲一区综合| 久久综合成人精品亚洲另类欧美| gay欧美网站| 亚洲天堂电影| 精品国产伦一区二区三区观看说明| 老**午夜毛片一区二区三区| 亚洲同性同志一二三专区| 在线免费精品视频| 日韩精品在线免费观看视频| 久久免费精品视频| 国产999在线| 成人精品视频在线| 国产视频在线观看网站| av在线理伦电影| 国产视频青青| 头脑特工队2免费完整版在线观看| 成人丁香基地| 东京一区二区| 精品国内亚洲2022精品成人| 欧美天堂一区| 日本美女一区| 亚洲视频分类| 国产精品久久夜| 91久久国产最好的精华液| 日本高清无吗v一区| 欧美激情影音先锋| 蜜臀av亚洲一区中文字幕| 国产精品jizz在线观看美国| 欧美精品导航| 日本视频一区二区| 久久精品欧美日韩| 亚洲天堂a在线| 精品欧美乱码久久久久久1区2区| 综合网中文字幕| 一本大道久久a久久精二百 | 免费全黄无遮挡裸体毛片| 国产精品18久久久久久麻辣| 成人精品在线观看| 成人免费视频网站| 国产精品久久一区二区三区| 国产伦精品一区二区三区照片| 国产成人综合一区二区三区| 国产精品入口免费视频一| 国产精品99免视看9| 国内精品久久久久| 青青草视频在线免费播放| 中文字幕有码在线视频| 一区二区动漫| 精品成人av一区| www.成人三级视频| 绯色av一区二区| 香蕉久久夜色精品国产更新时间| 中文欧美字幕免费| 国产成人一区二| 免费在线视频一级不卡| 国产社区精品视频| 九九九久久久精品| 午夜日韩在线观看| 日韩中文字幕一区| 日本成人伦理电影| 成人aa视频在线观看| 66m—66摸成人免费视频| 最新在线地址| 国产精品中文字幕制服诱惑| 伊人一区二区三区| 亚洲尤物视频网| 超碰一区二区| 久久久99久久| 欧美在线免费看| 在线毛片网站| 国产在线精品一区二区夜色 | 日韩精品一区二区在线观看| juliaann成人作品在线看| 亚洲人成小说|