精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

一篇帶你實現(xiàn)一個會動的鴻蒙 LOGO

開發(fā) 前端
本文將帶大家簡單實現(xiàn)一個會動的鴻蒙 LOGO。而本文想嘗試的,是該 LOGO 的其他一些細(xì)節(jié),核心是倒影部分的水波效果。

[[422184]]

Hello 大家好,我是 Coco。本文將帶大家簡單實現(xiàn)一個會動的鴻蒙 LOGO。

emmm,寫本文的動機是之前在掘金看到一篇實現(xiàn)鴻蒙 LOGO 的文章 -- 產(chǎn)品經(jīng)理:鴻蒙那個開場動畫挺帥的 給咱們頁面也整一個唄[1]

鴻蒙的 LOGO 本身是這樣的:

該篇作者最終實現(xiàn)的是一個字母 O 的動畫展開過程:

而本文想嘗試的,是該 LOGO 的其他一些細(xì)節(jié),核心是倒影部分的水波效果。

實現(xiàn)主體

首先,我們需要對該結(jié)構(gòu)進行簡單的一個拆解,因為上下部分的較大差異,雖然是一個圓,但是很明顯需要分成兩塊處理,這部分比較簡單且不是重點,我就略過分享,直接上代碼。

我們的結(jié)構(gòu)大致如下:

  1. <div class="g-container"
  2.     <div class="g-top"
  3.     </div> 
  4.     <div class="g-bottom"
  5.     </div> 
  6. </div> 
  1. @import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100;0,200;1,200&display=swap'); 
  2. .g-container { 
  3.     width: 100%; 
  4.     height: 100%; 
  5.     background: #000; 
  6. .g-top { 
  7.     position: fixed; 
  8.     top: 0; 
  9.     left: 0; 
  10.     width: 100vw; 
  11.     height: 50vh; 
  12.     overflow: hidden; 
  13.      
  14.     &::before { 
  15.         content: ""
  16.         position: absolute
  17.         border-radius: 50%; 
  18.         bottom: 0; 
  19.         left: 50%; 
  20.         width: 200px; 
  21.         height: 200px; 
  22.         transform: translate(-50%, 100px); 
  23.         box-sizing: border-box; 
  24.         background: #000; 
  25.         border: 25px solid #fff; 
  26.         z-index: 1; 
  27.         box-shadow:  
  28.             0 0 4px 1px rgba(255, 255, 255, .8), 
  29.             0 0 8px 2px rgba(255, 255, 255, .6); 
  30.     } 
  31. .g-bottom { 
  32.     position: fixed; 
  33.     top: 50vh; 
  34.     left: 0; 
  35.     width: 100vw; 
  36.     height: 50vh; 
  37.     background: #000; 
  38.     overflow: hidden; 
  39.      
  40.     &::before { 
  41.         content: ""
  42.         position: absolute
  43.         border-radius: 50%; 
  44.         top: 0; 
  45.         width: 200px; 
  46.         height: 200px; 
  47.         background: #000; 
  48.         left: 50%; 
  49.         transform: translate(-50%, -100px); 
  50.         box-sizing: border-box; 
  51.         border: 25px solid #fff; 
  52.         z-index: 2; 
  53.         box-shadow:  
  54.             0 0 4px rgba(255, 255, 255, .8), 
  55.             0 0 8px rgba(255, 255, 255, .7), 
  56.             0 0 20px rgba(255, 255, 255, .6); 
  57.         filter: blur(4px); 
  58.     } 

核心做的就是上下兩個半圓的實現(xiàn),以及對下面部分使用了模糊濾鏡 filter: blur(),我們可以初步得到這樣一個結(jié)構(gòu):

好吧,看著確實是平平無奇。

添加 SVG feTurbulence 濾鏡。實現(xiàn)水波倒影效果

OK,下面就是見證奇跡的時刻。我們給下部分的 g-bottom 添加一個 SVG feTurbulence 濾鏡,讓它產(chǎn)生水波倒影效果。

SVG feTurbulence 濾鏡在我的非常多篇文章中都有提到,turbulence 意為湍流,不穩(wěn)定氣流,而 SVG 濾鏡能夠?qū)崿F(xiàn)半透明的煙熏或波狀圖像。通常用于實現(xiàn)一些特殊的紋理。濾鏡利用 Perlin 噪聲函數(shù)創(chuàng)建了一個圖像。噪聲在模擬云霧效果時非常有用,能產(chǎn)生非常復(fù)雜的質(zhì)感,利用它可以實現(xiàn)了人造紋理比如說云紋、大理石紋的合成。

  • 如果你對 SVG 濾鏡還不算太了解,可以簡單看看我的這幾篇文章入門:有意思!強大的 SVG 濾鏡[2] 以及這篇實戰(zhàn)篇:震驚!巧用 SVG 濾鏡還能制作表情包?[3]

emmm,所以步驟是:

  1. 實現(xiàn)一個 SVG feTurbulence 效果
  2. 加上 SVG animation 動畫,
  3. 再通過 CSS Filter 引用至濾鏡到 DOM 結(jié)構(gòu)之上
  1. <!-- HTML 結(jié)構(gòu)下的 SVG 代碼 --> 
  2. <svg> 
  3.     <filter id="fractal" filterUnits="objectBoundingBox" x="0%" y="0%" width="100%" height="100%"
  4.         <feTurbulence id="turbulence" type="fractalNoise" baseFrequency="0.01 0.01" numOctaves="10"
  5.             <animate 
  6.                  attributeName="baseFrequency" 
  7.                  dur="30s"  
  8.                  values="0.01 0.01;0.03 0.15;0.01 0.01" 
  9.                  repeatCount="indefinite" /> 
  10.         </feTurbulence> 
  11.         <feDisplacementMap in="SourceGraphic" scale="15"></feDisplacementMap> 
  12.     </filter> 
  13. </svg> 
  1. .g-bottom { 
  2.     // 通過 Filter 引用 SVG 濾鏡到 DOM 結(jié)構(gòu)之上 
  3.     filter: url(#fractal); 

Wow,僅僅是一個濾鏡的疊加,就瞬間讓動畫高大上了起來。這也是 SVG feTurbulence 濾鏡的魅力所在,完成了 CSS 一些無法實現(xiàn)的功能。

通過漸變及 MASK 實現(xiàn)光圈

再看看原圖,還有一圈圈的藍(lán)色光圈,這個使用 repeating-radial-gradient 及 mask 可以實現(xiàn)。

簡單的代碼如下:

  1. <div></div> 
  1. div { 
  2.     background: repeating-radial-gradient(circle at 50% 100%, transparent, transparent 5px, #2c5ec8 5.2px, #2c5ec8 6.2px, transparent 6.5px); 
  3.     mask: radial-gradient(circle at 50% 100%, rgba(255, 255, 255, .8), transparent 25%, transparent); 

repeating-radial-gradient 配合 mask 實現(xiàn)漸隱的光圈效果,結(jié)果如下:

把這個光圈往效果里疊加,及其他一些小細(xì)節(jié)及文字,最終可以實現(xiàn)一個這樣的 LOGO 效果(雖然也不是很像,還有很多細(xì)節(jié)沒還原):

完整的代碼你可以猛擊這里:CSS 靈感 -- SVG 濾鏡及 filter: blur 實現(xiàn)鴻蒙 LOGO[4]

腦洞一下

運用上述的 SVG feTurbulence 濾鏡,我們能不能再搞點事情呢?

我們可以利用它,嘗試去實現(xiàn)這樣的效果,實現(xiàn)圖片的部分動態(tài)波動,運用在特定的場景,能夠非常大的提升用戶體驗,讓人“哇塞”一下:

又或者是:

(圖片幀率有點低,放大看遠(yuǎn)處的天際線)

上述兩個效果來自:tympanus - Distortion Effect[5],但是它們并非是使用 CSS + SVG 實現(xiàn),而是使用的 WebGL,但是它們確實可以用上述的方式復(fù)現(xiàn)。

假設(shè)我們有這樣一張圖:

下面,我們就利用 SVG feTurbulence 讓中間的石頭波動起來:

  1. 我們讓兩張一模一樣的圖疊加在一起(使用 div 及它的偽元素即可)
  2. 利用 clip-path 將疊在上層的圖中的石頭切割出來
  3. 利用 SVG feTurbulence 將濾鏡作用給上層的圖片

完整的代碼如下:

  1. <div></div> 
  2.  
  3. <svg> 
  4.     <filter id="fractal" filterUnits="objectBoundingBox" x="0%" y="0%" width="100%" height="100%"
  5.         <feTurbulence id="turbulence" type="fractalNoise" baseFrequency="0.005 0.005" numOctaves="10"
  6.             <animate 
  7.                  attributeName="baseFrequency" 
  8.                  dur="60s"  
  9.                  values="0.005 0.005;0.003 0.03;0.005 0.005" 
  10.                  repeatCount="indefinite" /> 
  11.         </feTurbulence> 
  12.         <feDisplacementMap in="SourceGraphic" scale="15"></feDisplacementMap> 
  13.     </filter> 
  14. </svg> 
  1. div { 
  2.     position: relative
  3.     width: 600px; 
  4.     height: 400px; 
  5.     background-image: url(https://z3.ax1x.com/2021/09/05/hWPVqe.jpg); 
  6.      
  7.     &::before { 
  8.         content: ""
  9.         position: absolute
  10.         top: 0; 
  11.         left: 0; 
  12.         bottom: 0; 
  13.         right: 0; 
  14.         background: inherit; 
  15.         clip-path: polygon(225px 50px, 320px 50px, 320px 90%, 225px 90%); 
  16.         filter: url(#fractal); 
  17.     } 

這樣,我們就能得到一張動起來的石頭,我們利用一張靜態(tài)圖,實現(xiàn)了其中部分的動態(tài)波動效果:

CodePen Demo -- SVG feTurbulence Image Effect[6]

利用這個技巧,我們可以很輕松的還原上述兩個使用 WebGL 實現(xiàn)的效果。Amazing~

最后

好了,本文到此結(jié)束,希望對你有幫助 :)

參考資料

[1]產(chǎn)品經(jīng)理:鴻蒙那個開場動畫挺帥的 給咱們頁面也整一個唄:

https://juejin.cn/post/6979042510400126983

[2]有意思!強大的 SVG 濾鏡:

https://github.com/chokcoco/cnblogsArticle/issues/27

[3]震驚!巧用 SVG 濾鏡還能制作表情包?:

https://github.com/chokcoco/iCSS/issues/107

[4]CSS 靈感 -- SVG 濾鏡及 filter: blur 實現(xiàn)鴻蒙 LOGO:

https://csscoco.com/inspiration/#/./svg/svg-feTurbulence-harmony-logo.md

[5]tympanus - Distortion Effect:

https://tympanus.net/Tutorials/HeatDistortionEffect/index3.html

[6]CodePen Demo -- SVG feTurbulence Image Effect:

https://codepen.io/Chokcoco/pen/VwWKxdb

 

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

2022-11-21 18:01:24

CSSthree.js

2022-04-08 08:32:40

mobx狀態(tài)管理庫redux

2021-05-20 06:57:16

RabbitMQ開源消息

2023-04-20 08:00:00

ES搜索引擎MySQL

2021-08-11 07:02:21

npm包管理器工具

2021-06-16 08:28:25

unary 方法函數(shù)技術(shù)

2022-02-24 07:56:42

開發(fā)Viteesbuild

2025-01-17 07:00:00

2021-05-18 05:40:27

kubebuilderwebhook進階

2021-05-12 06:18:19

KubeBuilderOperatork8s

2022-03-10 08:31:51

REST接口規(guī)范設(shè)計Restful架構(gòu)

2021-05-17 05:51:31

KubeBuilderOperator測試

2021-08-23 06:25:57

CSS 技巧animation

2024-05-28 09:21:25

2022-12-20 08:22:42

CommitMuation

2022-02-18 08:54:21

docker操作系統(tǒng)Linux

2022-05-05 07:40:07

maskCSS

2022-01-17 08:56:05

CSS 技巧代碼重構(gòu)

2021-05-16 10:52:58

kubebuilderstatus event

2022-02-21 09:44:45

Git開源分布式
點贊
收藏

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

91一区二区三区| 日韩中文在线中文网在线观看| www.av片| 国产高清自拍视频在线观看| 久久国产成人午夜av影院| 九九九久久久久久| 黄色aaa视频| 国产精品色婷婷在线观看| 性久久久久久久久| 在线观看成人av| 五十路在线视频| 久久er99精品| 浅井舞香一区二区| 欧美日韩三级在线观看| 欧美激情在线免费| 亚洲第一av网站| 天天综合成人网| 欧美xxx视频| 亚洲一区二区五区| 亚洲一区二区三区免费观看| 深夜福利视频网站| 国产美女精品人人做人人爽| 欧美在线免费视频| 在线免费日韩av| 欧美特黄一级大片| 日韩精品视频三区| 国产精品无码自拍| 懂色av色香蕉一区二区蜜桃| 色婷婷久久综合| 欧美在线一区视频| 一色桃子av在线| 国产精品久久精品日日| 欧美日韩一区二区视频在线 | 亚洲一区欧美二区| 不用播放器成人网| 免费成人深夜蜜桃视频| 国产不卡av一区二区| 亚洲国产另类久久精品| 美女网站视频在线观看| 亚洲欧美在线人成swag| 欧美日韩日本视频| 天天干在线影院| 日韩av中字| 天天影视网天天综合色在线播放| 亚洲乱码日产精品bd在线观看| 欧洲美女少妇精品| 国产精品国产自产拍高清av| 日韩国产高清一区| 精品99又大又爽又硬少妇毛片 | 欧美一级一区二区| 欧美日韩久久婷婷| 91麻豆精品国产综合久久久 | a级大片免费看| 精品国产亚洲一区二区三区| 51精品国自产在线| 天天操精品视频| 在线日韩三级| 日韩亚洲欧美在线| 一二三区视频在线观看| 高清精品视频| 精品一区二区三区电影| 一道本在线观看| 沈樵精品国产成av片| 亚洲香蕉成人av网站在线观看| 亚洲最大成人网站| 欧美一级精品片在线看| 综合136福利视频在线| 手机在线中文字幕| 欧美激情第8页| 欧美激情手机在线视频 | 日韩精品一区二区三区四区视频| 九九九久久久久久久| 亚洲日本va午夜在线电影| 亚洲第一页自拍| 一卡二卡三卡四卡| 久久日文中文字幕乱码| 久久精视频免费在线久久完整在线看| 成人性生活毛片| 亚洲福利久久| 国产精品成av人在线视午夜片| 一区精品在线观看| 国产精品资源站在线| 精品国产91亚洲一区二区三区www| 天天av综合网| 国产精品久久久久久久第一福利| 日本老太婆做爰视频| 国产高潮在线| 欧美色爱综合网| 国产老头和老头xxxx×| 秋霞蜜臀av久久电影网免费| 在线播放精品一区二区三区| 91久久国产综合| 国产欧美一级| 91久久国产精品91久久性色| 亚洲视频在线一区观看| 国产精品免费视频久久久| 99久久久久成人国产免费| 不卡一区中文字幕| 亚洲一区bb| www.超碰在线| 777xxx欧美| 久久久久久国产精品无码| 亚洲一区在线| 欧亚精品中文字幕| www.xxx国产| 国产日韩精品一区| 激情五月婷婷六月| 日本午夜精品久久久久| 亚洲国产高清福利视频| 中文字幕91视频| 亚洲女人av| 91蜜桃网站免费观看| 国产视频在线看| 亚洲第一主播视频| 亚洲一区二区在线视频观看| 日韩精品社区| 欧美福利在线观看| 一级成人免费视频| 久久久夜色精品亚洲| 久久香蕉视频网站| 精品176极品一区| 亚洲人午夜精品| 日韩特黄一级片| 国产精品综合在线视频| 亚洲精品在线观看免费| 欧美亚洲韩国| 国产丝袜一区二区三区免费视频| 久久久久久久久久久网| 精品夜夜嗨av一区二区三区| 亚洲a∨一区二区三区| 美女100%一区| 亚洲加勒比久久88色综合| 欧美成人一二三区| 国产精品自拍av| 无码人妻精品一区二区三区99v| 成人亚洲视频| 亚洲性生活视频在线观看| 国产精品老女人| 波多野结衣亚洲一区| 91免费版看片| 久久久久毛片免费观看| 精品国产拍在线观看| 中文字幕永久在线视频| 久久精品人人爽人人爽| 日韩手机在线观看视频| 久久综合色占| 国产精品精品视频一区二区三区| 免费理论片在线观看播放老| 欧美视频在线看| 精品少妇一区二区三区免费观| 免费亚洲一区| 日本高清视频一区二区三区 | 婷婷综合伊人| 91在线观看免费高清| 成人短视频在线观看| 欧美一级黄色录像| 久久亚洲成人av| 成人国产在线观看| 欧美日韩在线一| 国产不卡一区| 91精品久久久久久久久久久久久久| av播放在线| 欧美一级xxx| 国产精品不卡av| 久久影院电视剧免费观看| 日韩中文字幕组| 色婷婷色综合| 亚洲综合中文字幕在线| 超碰中文在线| 亚洲欧美国产视频| 亚洲图片视频小说| 亚洲欧洲制服丝袜| 四季av综合网站| 日韩和欧美一区二区三区| 亚洲一区在线直播| 91精品尤物| 青青草一区二区| 米奇精品一区二区三区| 精品久久国产97色综合| 中文字幕在线播| 最近中文字幕一区二区三区| 国产精品成人免费一区久久羞羞| 免费在线日韩av| 在线精品亚洲一区二区| 嗯用力啊快一点好舒服小柔久久| 国产91在线视频| 顶级网黄在线播放| 亚洲奶大毛多的老太婆| 国产又粗又猛又黄| 性欧美疯狂xxxxbbbb| 手机看片日韩av| 成人性生交大片免费看中文网站| 99999精品视频| 亚洲色图二区| 欧美精品中文字幕一区二区| 国产精品欧美一区二区三区不卡| 日本aⅴ大伊香蕉精品视频| 精品孕妇一区二区三区| 亚洲欧洲美洲在线综合| 性色av蜜臀av| 欧美日韩综合色| 黄色片视频网站| 亚洲欧美怡红院| 右手影院亚洲欧美| 国产福利一区二区三区在线视频| 欧美xxxxx在线视频| 国产一区视频在线观看免费| 天天综合色天天综合色hd| 国产精东传媒成人av电影| 成人黄色免费网站在线观看| 欧美无毛视频| 91地址最新发布| 欧美人与禽猛交乱配| 日日狠狠久久偷偷四色综合免费| 日本五码在线| 亚洲风情亚aⅴ在线发布| 国产区精品在线| 在线看不卡av| 在线观看精品国产| 亚洲成人自拍网| 精品国产乱码久久久久久鸭王1| 国产欧美日韩不卡| 中国美女乱淫免费看视频| 成人免费高清视频| 久久黄色一级视频| 紧缚捆绑精品一区二区| 我看黄色一级片| 天堂va蜜桃一区二区三区漫画版| 欧美三级一级片| 狠狠爱成人网| a级片一区二区| 亚洲一区 二区 三区| 超碰在线免费观看97| 99久久99热这里只有精品| 亚洲不卡一卡2卡三卡4卡5卡精品| 国产一区二区三区亚洲| 国产精品初高中精品久久| gogo人体一区| 国产99在线免费| 北条麻妃一区二区三区在线观看| 97人人模人人爽人人喊38tv| 欧美日韩国产一区二区在线观看| 91在线观看免费网站| 国产一区二区三区精品在线观看| 91亚洲精品久久久久久久久久久久| 欧美三级电影网址| 成人黄色片在线| 久久伦理中文字幕| 国产精品国产精品国产专区不卡| 超碰成人在线观看| 国产原创精品| 九九热线有精品视频99| 欧美亚洲国产免费| 成人免费看片39| 国产又粗又爽又黄的视频| 亚洲综合婷婷| 极品粉嫩国产18尤物| 亚洲欧美日韩国产| av在线无限看| 国产一区二区精品在线观看| 中文字幕在线观看视频www| 成人99免费视频| 一色道久久88加勒比一| 国产精品美女一区二区| 精品国产精品国产精品| 亚洲第一av色| 波多野结衣视频观看| 欧美日韩午夜精品| 亚洲欧美高清视频| 亚洲乱码国产乱码精品精天堂| av中文字幕一区二区三区| 久久亚洲精品一区二区| 超级白嫩亚洲国产第一| 国产精品第100页| 日韩欧美久久| 久久免费看av| 91成人精品| 久久网站免费视频| 美国毛片一区二区| 久久久久无码国产精品一区李宗瑞| 91蝌蚪porny九色| 成人黄色短视频| 亚洲国产色一区| 最新中文字幕在线观看视频| 日韩一区二区在线看片| 欧美精品a∨在线观看不卡| 久久精品99久久久久久久久| 51精品在线| 成人高h视频在线| 欧美一区自拍| 最新精品视频| 母乳一区在线观看| 亚洲av无一区二区三区久久| 久久久激情视频| 免费人成在线观看| 欧美视频在线播放| 天堂av在线免费| 久久久精品欧美| 欧美xxx网站| 国产一区在线免费观看| 91精品电影| 午夜视频你懂的| jvid福利写真一区二区三区| 精品无码一区二区三区蜜臀 | 久久夜精品香蕉| 欧美美女日韩| 国内精品久久国产| 一区二区电影在线观看| 精品久久久噜噜噜噜久久图片| 成人高清av在线| 一级片一级片一级片| 91福利区一区二区三区| 午夜影院在线视频| 美女精品久久久| 久久91视频| 欧美一区二区三区四区夜夜大片| 亚洲午夜一区| 又黄又爽又色的视频| 国产精品久久久久影院| 黄色网址中文字幕| 亚洲美女免费精品视频在线观看| 国产又色又爽又黄刺激在线视频| 国产日韩精品在线| 成人黄色av| 天天干在线影院| 国产三级一区二区三区| av黄色在线播放| 亚洲国产福利在线| av人人综合网| 国产精品一区二区欧美黑人喷潮水 | 欧美一区二区三区系列电影| aaa在线观看| 国产精品露脸av在线| 国内精品久久久久久久久电影网| 欧美日韩二三区| 99久久精品久久久久久清纯| 国产亚洲精品成人| 精品国一区二区三区| 欧美xxxx免费虐| 国产精品久久久久久久久久久久冷 | 成人一区二区三区视频 | 亚洲精品色图| yy1111111| 欧美性感美女h网站在线观看免费| 少妇精品视频一区二区| 高清亚洲成在人网站天堂| www.成人网| 男人日女人视频网站| 成人18视频在线播放| 一级片免费网址| 日韩经典第一页| 制服丝袜专区在线| 日韩精品久久一区| 日日夜夜精品视频免费| 美国美女黄色片| 在线播放亚洲一区| 日日夜夜天天综合入口| 国模精品一区二区三区| 免费久久99精品国产自在现线| 日本激情小视频| 欧美色窝79yyyycom| 国内精品不卡| 国产欧美韩日| 久久久水蜜桃av免费网站| 女人十八毛片嫩草av| 在线综合+亚洲+欧美中文字幕| 四虎影院观看视频在线观看| 好吊色欧美一区二区三区四区| 亚洲男女自偷自拍| 青花影视在线观看免费高清| 亚洲成人1234| 欧美不卡高清一区二区三区| 老司机av福利| 99精品1区2区| 又污又黄的网站| 欧美精品在线观看| 亚洲裸色大胆大尺寸艺术写真| 一级黄色录像在线观看| 亚洲综合精品自拍| jizz在线观看视频| 亚洲最大av在线| 午夜亚洲视频| 5566中文字幕| 亚洲高清一二三区| 亚洲欧洲二区| 亚欧无线一线二线三线区别| 国产精品久久久久久妇女6080| 人人妻人人澡人人爽久久av| 国产精品精品视频| 在线日本高清免费不卡| 老头老太做爰xxx视频| 欧美成人艳星乳罩| 成人看片网页| 高清欧美精品xxxxx| 国产精品久久久久久久久免费相片| 色欲av伊人久久大香线蕉影院| 国产欧美日韩专区发布| 亚洲一区二区伦理| 美国黄色小视频| 中文字幕日本欧美|