摘要:我目前找不到很高效的轉(zhuǎn)化方式,就用標(biāo)注軟件標(biāo)注完后,手工錄入最后畫了個就結(jié)束了?;蛘吣阌泻芎玫姆绞浇榻B,請一定要告訴我。
前段時間朋友介紹了一個很帥的網(wǎng)站 http://www.species-in-pieces.com/
F12看了一下 Dom 結(jié)構(gòu),發(fā)現(xiàn)作者只是結(jié)合了 CSS3 的 clip-path 和 transition 特性,就實現(xiàn)了很厲害的效果,每個轉(zhuǎn)場和動物的細節(jié)都做得很棒。
然后我根據(jù)自己的理解做了一個Demo, 并將核心js部分打包了出來,歡迎感興趣的朋友一起交流
預(yù)覽地址: https://luosijie.github.io/ani-clipath/ 源碼地址: https://github.com/luosijie/ani-clipath 實現(xiàn)過程Demo中的圖片來自 https://www.behance.net/tomanders, 我只是做了低邊處理
先從一個簡單的 clip-path 變形開始
simple move
這就是Demo中所需要的基本動畫 變形 + 變色, 至于如何構(gòu)建精美的圖形變化, 就需要一點想象力和設(shè)計能力了
設(shè)計我們需要先設(shè)計出滿意的低邊圖案,注意控制三角形的數(shù)量,越少越好越少越好越少越好越少越好越少越好越少越好
接下來,需要將每個三角形的坐標(biāo)和色值轉(zhuǎn)化為數(shù)據(jù)格式。我目前找不到很高效的轉(zhuǎn)化方式,就用標(biāo)注軟件標(biāo)注完后,手工錄入,最后畫了3個就結(jié)束了。所以三角形的數(shù)量越少越好越少越好越少越好越少越好越少越好越少越好。
或者你有很好的方式介紹,請一定要告訴我。
現(xiàn)在準(zhǔn)備工作完成了,最痛苦的階段也已經(jīng)過去了
碼起代碼實現(xiàn)的基本思路是這樣的
每個動物都是由 36 個不同顏色的三角形拼接而成, 所以需要 36 個 div 來顯示
每一次變化都將 36 個div 的 clip-path 屬性重新賦值
每個 div 都設(shè)置 transition 屬性, 讓轉(zhuǎn)場自動實現(xiàn)
區(qū)區(qū)幾行代碼就不貼出來了,感興趣的移步 github
不過我想介紹一下封裝好的插件的使用方法 安裝 CDN NPMnpm install --save ani-clipath使用
需要自定義一個 DOM 容器,并設(shè)置好width和height
...
初始化一個實例,并傳入?yún)?shù)
參數(shù) | 類型 | 說明 |
---|---|---|
el | String | 綁定DOM容器 |
speed | Number | 控制變化速度 |
delay | Number | 控制變化的延遲 |
shapes | Array | 低邊圖形的坐標(biāo) |
使用公共方法切換
方法 | 說明 |
---|---|
next() | 切換下一個圖形 |
previous() | 切換上一個圖形 |
shapes 屬性的數(shù)據(jù)格式
var data = [ ?第 1 個低邊圖形 ?[ ? ?// 基本圖形參數(shù) ? ?{ ? ? ?// 顏色 ? ? ?c: "#1A1A1A", ? ? ?// polygon坐標(biāo) ? ? ?p: [ { x: "50%", y: "30%" }, { x: "30%", y: "70%" }, { x: "70%", y: "70%" }] } ... ?], ?第 2 個低邊圖形 ?[ { c: "#E6E6E6", p: [ { x: "50%", y: "70%" }, { x: "30%", y: "30%" }, { x: "70%", y: "30%" }] } ... ] ... ?第 n 個低邊圖形 ]
先這樣了 歡迎star
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/88750.html
摘要:整體來說網(wǎng)頁主要是由矩形所構(gòu)成的,另一方面印刷品則具備相對多樣性。即便我們設(shè)定的元素不再是矩形,但周圍的元素排列方式仍然維持原本矩形的佈局。為了達成周圍的元素跟著裁切的形狀,我們可以使用屬性。周圍的元素仍需要靠來修正。 整體來說網(wǎng)頁主要是由矩形所構(gòu)成的,另一方面印刷品則具備相對多樣性。造成這樣差異的原因有很多,不過其中一個即是缺少合適的工具。 這篇文章主要會介紹 clip-path 這...
摘要:介紹直譯過來就是裁剪路徑,使用或形狀定義一個元素的可見區(qū)域的方法。想象一下你在中勾勒路徑的場景。上是這樣介紹的屬性可以防止部分元素通過定義的剪切區(qū)域來顯示,僅通過顯示的特殊區(qū)域。屬性代替了現(xiàn)在已經(jīng)棄用的剪切屬性。clip-path介紹 clip-path 直譯過來就是裁剪路徑,使用SVG或形狀定義一個HTML元素的可見區(qū)域的方法。想象一下你在Photoshop中勾勒路徑的場景。MDN上是這樣...
摘要:一個用來生成各種形狀包括隨意拖拉自定義并且可以直接生成代碼的網(wǎng)站。兼容性目前兼容性較差,和直接不支持,考慮兼容性的同學(xué)可以暫時等等。透明區(qū)域表示被裁剪的區(qū)域基本圖形定義一個矩形。語法說明可選,表示填充規(guī)則用來確定該多邊形的內(nèi)部。 本文首發(fā)于 我的博客 曾經(jīng)和某位朋友在聊天中討論過這樣一個話題:綜合90%的網(wǎng)站的布局以及頁面中的元素不是方的,就是圓的。就像所有的顏色都是由三原色(RGB)...
摘要:的使用值為多個坐標(biāo)點組成,坐標(biāo)第一個值是方向,第二個值是方向。值為橢圓的軸半徑,軸半徑,定位橢圓的坐標(biāo)三部分組成。 clip-path的使用 polygon 值為多個坐標(biāo)點組成,坐標(biāo)第一個值是x方向,第二個值是y方向。 左上角為原點,右下角是(100%,100%)的點。 body { background-color: #000; } .fa { border: 1px ...
閱讀 2088·2021-09-29 09:35
閱讀 692·2021-09-08 09:36
閱讀 3400·2021-09-03 10:30
閱讀 2118·2019-08-30 14:21
閱讀 2915·2019-08-30 11:18
閱讀 3319·2019-08-29 17:31
閱讀 3147·2019-08-29 17:29
閱讀 1314·2019-08-29 17:13