精品欧美一区二区三区在线观看 _久久久久国色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ù)棧公眾號

青青精品视频播放| 精品区一区二区| 日韩av一级大片| 91tv国产成人福利| 欧美va天堂在线| 亚洲黄色免费三级| 中文字幕有码av| 青青草原av在线| 91亚洲国产成人精品一区二三| 日韩免费在线视频| 国产高潮国产高潮久久久91| 日本国产精品| 91.成人天堂一区| 欧美黑人在线观看| 国产视频三级在线观看播放| 国产一区二区三区在线观看免费 | 美女扒开腿免费视频| 欧美xxxxxx| 亚洲在线一区二区三区| 日本视频一区二区不卡| 午夜精品在线播放| 日韩成人精品在线观看| 欧美激情一区二区久久久| 夫妇露脸对白88av| 奇米777国产一区国产二区| 欧美日韩亚洲不卡| 99爱视频在线| 直接在线观看的三级网址| 久久婷婷国产综合国色天香| 91嫩草视频在线观看| 国产乱码在线观看| 国产精品日韩| 欧美精品九九久久| 国产精品成人69xxx免费视频 | 亚洲福利视频网| 色天使在线观看| 日韩新的三级电影| 黄色精品在线看| 一本大道东京热无码aⅴ| jzzjzzjzz亚洲成熟少妇| 91丨porny丨国产入口| 99理论电影网| 精品久久久久成人码免费动漫| 日本视频中文字幕一区二区三区 | 我爱我色成人网| 精品美女久久久久久免费| 日韩成人午夜影院| 国产午夜精品久久久久免费视| 日本一区二区三区视频视频| 欧美国产二区| 你懂的在线观看视频网站| 不卡一卡二卡三乱码免费网站| 亚洲影院污污.| 国产男女裸体做爰爽爽| 精久久久久久久久久久| 国产在线98福利播放视频| 欧美日韩在线视频播放| 久久精品盗摄| 国产成人a亚洲精品| 国产成人一级片| 蜜桃伊人久久| 国产99久久精品一区二区永久免费| 圆产精品久久久久久久久久久| 狠狠88综合久久久久综合网| 欧美高清自拍一区| 国产精品9191| 国产精品婷婷| 国产成人91久久精品| 国产成人av免费| 美女视频网站久久| 91在线视频一区| h狠狠躁死你h高h| 成人一区二区视频| 久久亚洲精品欧美| 国产黄在线看| 亚洲色图欧美在线| 精品无码国产一区二区三区av| 成年网站在线视频网站| 黑人欧美xxxx| 国产九九在线视频| 精品久久免费| 亚洲国产成人精品久久| 国产女主播喷水高潮网红在线| 欧美**vk| 久久中文字幕国产| 日韩av在线播| 日日夜夜精品视频免费| 成人a视频在线观看| 亚洲xxx在线| 91免费国产视频网站| 色播五月综合| 中文字幕中文字幕在线中高清免费版| 亚洲3atv精品一区二区三区| 99精品免费在线观看| 欧美风情在线视频| 亚洲国产精品va在看黑人| 欧美多人猛交狂配| 亚洲欧美亚洲| 国产精品电影久久久久电影网| 国产又爽又黄又嫩又猛又粗| 国产精品一区二区在线观看网站| 久久精品二区| 黄网站视频在线观看| 午夜欧美2019年伦理| 校园春色 亚洲色图| 亚洲视频国产精品| 亚洲色图在线观看| 久久机热这里只有精品| 丝袜亚洲另类欧美| 成人av播放| 在线视频婷婷| 欧美日韩国产一区二区三区| 中文字幕视频三区| 日韩大片在线免费观看| 久久久精品免费| 国产一级免费视频| 成人免费视频视频| 影音先锋欧美资源| 欧洲av不卡| 亚洲精品720p| 蜜臀久久精品久久久用户群体| 欧美中文日韩| 粉嫩av四季av绯色av第一区| 中文字幕在线播放| 色婷婷综合五月| 国产艳妇疯狂做爰视频 | 亚洲欧美日韩中文在线| 高h视频免费观看| 蜜臀av一区二区在线观看 | 噜噜噜久久,亚洲精品国产品| 国产欧美精品一区二区三区四区| 久久久久久久久久久99| 精品国产伦一区二区三区观看说明| 亚洲欧美精品中文字幕在线| 国产污视频在线看| 国产suv精品一区二区6| 四虎免费在线观看视频| jizz久久久久久| 亚洲欧美日韩第一区| 激情五月色婷婷| 成人性生交大片免费看中文网站| 综合视频在线观看| 色综合视频一区二区三区日韩| 亚洲午夜未删减在线观看| 青青草成人av| 99精品一区二区三区| 欧美国产综合在线| 91精品日本| 久久久免费在线观看| www.国产免费| 亚洲永久免费av| 日韩成人av影院| 国模大胆一区二区三区| 99久久精品久久久久久ai换脸| 精精国产xxxx视频在线| 7777精品伊人久久久大香线蕉的| 中文字幕91视频| 久久99精品视频| 在线综合视频网站| 欧美高清一级片| 欧美成人亚洲成人日韩成人| 国产高清第一页| 亚洲国产成人av| 国产精品300页| 久久激情中文| 伊人久久av导航| 欧美影院视频| 孩xxxx性bbbb欧美| 神马精品久久| 欧美日韩在线播| 欧美一区二区三区爽爽爽| 国产乱码精品一区二区三区五月婷| 51xx午夜影福利| 国产精品15p| 日韩av不卡电影| 18免费在线视频| 日韩一区二区免费视频| 日本三级中文字幕| 日本一区二区三区四区 | 国产一级片毛片| 中文字幕免费观看一区| 在线视频观看91| 尹人成人综合网| 日本视频一区二区在线观看| 亚洲aⅴ网站| 高清视频欧美一级| 电影在线一区| 日韩欧美在线网站| 亚洲影院在线播放| 日韩一区欧美一区| 高清中文字幕mv的电影| 久久综合网络一区二区| 国产av不卡一区二区| 任我爽精品视频在线播放| 国产精品视频一| 岛国毛片av在线| 尤物yw午夜国产精品视频明星 | 欧洲av不卡| 美女精品久久久| 日本一区高清| 91精品国产综合久久蜜臀| 日韩 欧美 综合| 成人免费在线观看入口| 男女一区二区三区| 久久国产精品免费| 国产美女三级视频| 欧美粗暴jizz性欧美20| 日本不卡高清视频一区| 日韩欧美中文字幕在线视频| 国产mv久久久| 都市激情久久综合| 久久伊人精品天天| 电影在线高清| 亚洲精品电影网| 精品黑人一区二区三区在线观看| 欧美中文字幕亚洲一区二区va在线| 九九视频免费在线观看| 欧美激情一区二区三区全黄| 制服丝袜第一页在线观看| 精品系列免费在线观看| 天天天干夜夜夜操| 国产农村妇女毛片精品久久莱园子| 欧美精品久久96人妻无码| 国产伦精品一区二区三区千人斩| 粉嫩av一区二区三区免费观看 | 99久久精品免费看国产一区二区三区| 国产69精品久久久久按摩| 美女精品视频一区| 免费大片黄在线| 国产亚洲欧美日韩精品| 视频国产一区二区三区| 亚洲黄色av女优在线观看| 亚洲国产成人一区二区| 91精品在线麻豆| 亚洲最大成人av| 欧美私人免费视频| 波多野结衣视频在线看| 欧美日韩国产在线| 国产福利拍拍拍| 亚洲国产一区视频| 妺妺窝人体色www聚色窝仙踪| 日韩一区中文字幕| 久久av红桃一区二区禁漫| 国产精品入口麻豆原神| 极品蜜桃臀肥臀-x88av| 国产视频911| 人妻视频一区二区| 国产欧美一区二区三区在线老狼 | 国产精品久久久久久福利一牛影视| 中文字幕第4页| 国产日产精品1区| 波多野结衣 在线| 久久久久国产免费免费| 国产小视频自拍| 国产日产欧美一区二区三区| 久久午夜福利电影| 国产精品毛片a∨一区二区三区| 我想看黄色大片| 亚洲图片激情小说| 欧美另类视频在线观看| 亚洲高清免费视频| 国产一区二区99| 色噜噜久久综合| jizz国产在线| 91精品国产色综合久久不卡蜜臀| aaa级黄色片| 精品粉嫩aⅴ一区二区三区四区| 免费看日韩av| 精品亚洲一区二区三区| 国产精品免费观看| 精品国模在线视频| 手机av在线播放| 欧美有码在线观看| 日韩视频网站在线观看| 国产精品免费视频久久久| va天堂va亚洲va影视| www日韩av| 亚洲自拍电影| 一本一道久久久a久久久精品91| 欧美在线看片| 精品欧美一区免费观看α√| 国产欧美综合一区二区三区| 天堂av在线网站| 福利一区二区在线| 亚洲久久久久久久| 尤物视频一区二区| 天堂网一区二区三区| 欧美日韩激情一区| 天堂中文在线观看视频| 中文欧美在线视频| 欧美xxxxhdvideosex| 日本91av在线播放| 粉嫩一区二区三区在线观看| 精品一区二区日本| 欧美激情偷拍自拍| 免费看黄在线看| 美国十次了思思久久精品导航| 日韩高清一二三区| 国产日韩av一区| 精品午夜福利视频| 精品视频在线免费观看| 成人免费视频国产| 色偷偷9999www| 午夜影院一区| 91中文字幕一区| 国产伦精品一区二区三区视频 | 一级特黄曰皮片视频| 亚洲在线视频一区| 一本色道久久综合无码人妻| 亚洲国产欧美一区| 中文在线观看免费| 国产精品1区2区在线观看| 国产精伦一区二区三区| 26uuu成人| 日产国产欧美视频一区精品| 这里只有精品在线观看视频| 亚洲欧美视频在线观看视频| 啦啦啦免费高清视频在线观看| 日韩午夜激情av| av电影在线观看一区二区三区| 性色av一区二区三区红粉影视| 国产aⅴ精品一区二区四区| 欧美高清性xxxxhdvideosex| 亚洲福利免费| 日本泡妞xxxx免费视频软件| 国产精品灌醉下药二区| 日本精品入口免费视频| 日韩成人xxxx| 丁香花在线电影小说观看| 亚洲一区亚洲二区| 91麻豆精品国产91久久久平台| 韩国一区二区av| 久久综合色婷婷| 99久在线精品99re8热| 亚洲第一偷拍网| 国产极品人妖在线观看| 91免费看片网站| 久久久久久久久99精品大| 天天干天天综合| 国产精品麻豆视频| 在线免费观看视频网站| 一区三区二区视频| 播放一区二区| 亚洲成人精品电影在线观看| 老牛嫩草一区二区三区日本| 六月婷婷七月丁香| 欧美在线免费视屏| yiren22综合网成人| 国产精品亚洲第一区| 日韩久久久久| 欧美国产日韩另类| 亚洲免费伊人电影| 午夜精品久久久久久久96蜜桃| 欧美理论片在线观看| 成人在线视频你懂的| 日韩小视频在线播放| 91香蕉视频污| 日本一本在线观看| 自拍亚洲一区欧美另类| 婷婷激情成人| 五月天激情图片| 成人a免费在线看| 青草视频在线观看免费| 亚洲欧美制服第一页| 成人福利片在线| 特级毛片在线免费观看| 国产精品一二三四区| 欧美亚洲天堂网| 亚洲欧美一区二区精品久久久 | 亚洲一区国产精品| 亚洲精品三级| av女人的天堂| 在线电影国产精品| av中文字幕在线看| 欧美黑人3p| 韩国精品一区二区| 国产一级特黄视频| 国产一区二区三区18| 亚洲网站三级| 99色这里只有精品| 国产三级三级三级精品8ⅰ区| 国产精品久久777777换脸| 欧美精品videos另类日本| 亚洲肉体裸体xxxx137| 日韩高清第一页| 亚洲国产精品久久不卡毛片| 国产高清视频在线观看| 3d动漫精品啪啪一区二区三区免费 | 日韩亚洲电影在线| 亚洲日本天堂| 制服诱惑一区| 99国产精品久久久久| 中文字幕 国产| 高清在线视频日韩欧美| 成人羞羞网站入口免费| 国产高潮失禁喷水爽到抽搐| 色一区在线观看| 激情网站在线| 亚洲精品国产精品国自产观看| 国产91精品欧美|