成人怡红院-成人怡红院视频在线观看-成人影视大全-成人影院203nnxyz-美女毛片在线看-美女免费黄

站長資訊網
最全最豐富的資訊網站

利用CSS也能輕松實現超酷炫的轉場動畫!

利用CSS也能輕松實現超酷炫的轉場動畫了!只需利用最新的 CSS @scroll-timeline 規范即可。下面本篇文章就通過兩個案例來看看利用@scroll-timeline怎么實現超酷炫的轉場動畫,希望對大家有所幫助!

利用CSS也能輕松實現超酷炫的轉場動畫!

在 WeGame 的 PC 端官網首頁,有著非常多制作精良的基于滾動的動畫效果。

這里我簡單截取其中 2 個比較有意思的轉場動畫,大家感受感受。轉場動畫 1:

利用CSS也能輕松實現超酷炫的轉場動畫!

轉場動畫 2:

利用CSS也能輕松實現超酷炫的轉場動畫!

是不是挺有意思的,整個動畫的銜接是基于滾輪的滾動觸發的。我猜測是使用了類似 TweenMaxJS 的動畫庫實現。

當然,這兩處酷炫有意思的轉場動畫,基于最新的 CSS @scroll-timeline 規范,也是可以大致實現的。本文就將嘗試使用純 CSS,模擬上述的兩個轉場動畫。【推薦學習:css視頻教程】

當然,關于 CSS 最新的 CSS @scroll-timeline 規范,如果你還沒有詳細了解過,可以先看看我的這篇文章 來了來了,它終于來了,動畫殺手锏 @scroll-timeline

轉場動畫一


首先,我們來看看這個動畫:

利用CSS也能輕松實現超酷炫的轉場動畫!

核心步驟拆解一下:

  • 處于場景 1,接著借助 WeGame 的 LOGO,LOGO 開始放大

  • LOGO 放大到一定程度,開始漸隱,LOGO 背后的場景 2 逐漸漸現

  • LOGO 放大且漸隱消失,場景 2 完全出現

這里,要實現整個動畫,有一個非常重要的場景,就是能夠利用 LOGO 元素,切割背景,只看到 LOGO 背后的元素,像是得到一張這樣的圖片:

利用CSS也能輕松實現超酷炫的轉場動畫!

注意,圖片的白色部分,不是白色,而是需要透明,能夠透出背后的元素

當然,我們可以讓 UI 切一張這樣的圖出來,但是畢竟太麻煩了。

假設我們只有一張 LOGO 元素:

利用CSS也能輕松實現超酷炫的轉場動畫!

我們如何能夠借助這個 LOGO,切割背景呢?

借助 mask 及 mask-composite 切割背景

是的,這里我們可以使用 mask。我們來嘗試一下:

<div></div>
div {     background: linear-gradient(-75deg, #715633, #2b2522); }

假設我們有這樣一張背景:

利用CSS也能輕松實現超酷炫的轉場動畫!

我們使用 LOGO 圖作為 MASK,對該背景進行切割:

div {     background: linear-gradient(-75deg, #715633, #2b2522);     mask: url(WeGame-LOGO圖.png);     mask-repeat: no-repeat;     mask-position: center center; }

我們會得到這樣一張圖:

利用CSS也能輕松實現超酷炫的轉場動畫!

Oh No,這與我們想象的剛好相反,我們要的是 LOGO 處透明,背景的其他處保留

怎么做呢?不要慌,這里可以使用上我們上一篇文章介紹過的 -webkit-mask-composite,還不太了解的可以戳這里看看:高階切圖技巧!基于單張圖片的任意顏色轉換

我們簡單改造一下代碼:

div {     background: linear-gradient(-75deg, #715633, #2b2522);     mask: url(//wegame.gtimg.com/g.55555-r.c4663/wegame-home/sc01-logo.52fe03c4.svg), linear-gradient(#fff, #fff);     mask-repeat: no-repeat;     mask-position: center center;     -webkit-mask-composite: xor; }

這樣,我們能就順利的得到了這樣一張圖形:

利用CSS也能輕松實現超酷炫的轉場動畫!

當然這里需要注意的是,白色區域并非白色,而是透明的,可以透出背后的內容。

配合 @scroll-timeline

好,如此一來,基于上述的剪切層,再配合 @scroll-timeline,我們來模擬一個最基本的動畫效果:

<div class="g-scroll" id="g-scroll"></div> <div class="g-wrap">     <div class="g-bg"></div>     <div class="g-container">         <div class="g-wegame"></div>     </div> </div>
.g-scroll {     position: relative;     width: 100vw;     height: 500vh; } .g-wrap {     position: fixed;     top: 0;     left: 0;     width: 100vw;     height: 100vh;     overflow: hidden; } .g-container {     position: absolute;     top: 0;     left: 0;     width: 100vw;     height: 100vh;     animation-name: scale;     animation-duration: 10s;     animation-timeline: box-move; } .g-bg {     position: fixed;     width: 100vw;     height: 100vh;     background: url(LOGO背后的圖層); } .g-wegame {     position: absolute;     width: 100vw;     height: 100vh;     background: linear-gradient(-75deg, #715633, #2b2522);     mask: url(//wegame.gtimg.com/g.55555-r.c4663/wegame-home/sc01-logo.52fe03c4.svg), linear-gradient(#fff, #fff);     mask-repeat: no-repeat;     mask-position: center center;     -webkit-mask-composite: xor; } @scroll-timeline box-move {     source: selector("#g-scroll");     orientation: "vertical"; } @keyframes scale {     0% {         transform: scale(1);     }     100% {         transform: scale(60);     } }

這里,想要看懂上述代碼,你必須已經掌握了基本的 CSS @scroll-timeline 語法。其余的內容,簡單解釋下:

  • 我們在 LOGO 后面的圖層,用 .g-bg 使用一張圖片表示了場景 2

  • #g-scroll 用于基于滾動條的滾動,實現滾動動畫

  • .g-wegame 里面就是上述使用 maskmask-composite 實現的圖層

好,此時,我們向下滾動動畫,就會觸發 .g-container 的動畫,也就是從 transform: scale(1)transform: scale(60),我們來看看效果:

利用CSS也能輕松實現超酷炫的轉場動畫!

有點那個意思了。但是,這里還缺少了一些細節

首先我們需要有一個 LOGO,它的透明度從 1 逐漸漸隱到 0,這個比較簡單,加完之后,我們看看效果:

利用CSS也能輕松實現超酷炫的轉場動畫!

離目標又近了一步,但是,仔細觀察原效果,我們還少了一層:

利用CSS也能輕松實現超酷炫的轉場動畫!

在 LOGO 漸隱的過程中,背后的背景不是直接呈現的,而是有一個漸現的過程。所以,完整而言,在動畫過程從,一共會有 4 層:

利用CSS也能輕松實現超酷炫的轉場動畫!

所以,完整的代碼,大概是這樣的:

<div class="g-scroll" id="g-scroll"></div> <div class="g-wrap">     <div class="g-bg"></div>     <div class="g-container">         <div class="g-wegame"></div>         <div class="g-mask"></div>         <div class="g-logo"></div>     </div> </div>
.g-scroll {     position: relative;     width: 100vw;     height: 500vh; } .g-wrap {     position: fixed;     top: 0;     left: 0;     width: 100vw;     height: 100vh;     overflow: hidden; } .g-container {     position: absolute;     top: 0;     left: 0;     width: 100vw;     height: 100vh;     animation-name: scale;     animation-duration: 10s;     animation-timeline: box-move; } .g-bg {     position: fixed;     width: 100vw;     height: 100vh;     background: url(//背景圖片,場景2); } .g-wegame {     position: absolute;     width: 100vw;     height: 100vh;     background: linear-gradient(-75deg, #715633, #2b2522);     mask: url(//WeGame-Logo.png), linear-gradient(#fff, #fff);     mask-repeat: no-repeat;     mask-position: center center;     -webkit-mask-composite: xor;     z-index: 1; } .g-mask {     position: aboslute;     width: 100vw;     height: 100vh;     background: linear-gradient(-75deg, #715633, #2b2522);     z-index: 2;     animation-name: reOpacityChange;     animation-duration: 10s;     animation-timeline: box-move;     animation-function-timing: linear; } .g-logo {     position: absolute;     background: url(//WeGame-Logo.png);     background-repeat: no-repeat;     background-position: center center;     z-index: 3;     animation-name: reOpacityChange;     animation-duration: 10s;     animation-timeline: box-move; } @scroll-timeline box-move {     source: selector("#g-scroll");     orientation: "vertical"; } @keyframes reOpacityChange {     0%,     50% {         opacity: 1;     }     100% {         opacity: 0;     } } @keyframes scale {     0% {         transform: scale(1);     }     100% {         transform: scale(60);     } }

這樣,我們就基本能夠還原原效果了:

利用CSS也能輕松實現超酷炫的轉場動畫!

完整的代碼,你可以戳這里:CodePen Demo – WeGame Animation Demo

轉場動畫二


好,搞定了一個,我們繼續來看下一個:

利用CSS也能輕松實現超酷炫的轉場動畫!

這里,我們也簡單拆解下動畫:

  • 數字放大,逐漸帶出場景 2

  • 場景 2 有一個非常酷炫的光影收縮效果

這里的數字放大與第一個轉場動畫其實非常類似,就不詳細講了。

我們來看看,在場景 2 這里,光影的收縮效果如何實現

這里看似負責,但是,其實非常的簡單。這里,核心在于這兩張圖片:

圖片素材 1:

利用CSS也能輕松實現超酷炫的轉場動畫!

注意,這里最為核心的在于,圖片中的白色不是白色,是透明的,可以透出背景的內容。

這樣,我們只需要在這張圖片的背后,放置另外這樣一張圖片:

利用CSS也能輕松實現超酷炫的轉場動畫!

想到了嗎?沒錯,就是讓這張圖片從一個較大的 transform: scale() 值,變化到一個較小的 transform: scale() 值即可!

什么意思呢?看看這張圖你就懂了:

利用CSS也能輕松實現超酷炫的轉場動畫!

知道了解到這一點,整個動畫也就比較簡單了。當然,這里我們也同樣借助了 CSS @scroll-timeline 完成整個動畫:

<div class="g-scroll" id="g-scroll"></div> <div class="g-container">     <div class="g-bg"></div>     <div class="g-circle"></div>     <div class="g-word">30</div> </div>
.g-scroll {     position: relative;     width: 100vw;     height: 500vh; } .g-container {     position: fixed;     top: 0;     left: 0;     width: 100vw;     height: 100vh;     overflow: hidden; } .g-bg {     position: absolute;     top: 0;     left: 0;     width: 100%;     height: 100%;     background: url(//蜂巢圖片.png);     z-index: 1; } .g-circle {     position: absolute;     top: 50%;     left: 50%;     transform: translate(-50%, -50%) scale(.5);     width: 400px;     height: 400px;     background: url(//光圈圖片.png);     animation-name: scale;     animation-duration: 10s;     animation-timeline: box-move; } .g-word {     position: absolute;     top: 50%;     left: 50%;     transform: translate(-50%, -50%);     font-size: 12vw;     z-index: 10;     color: transparent;     background: linear-gradient(#f8a011, #ffd973);     background-clip: text;     animation-name: scaleWord;     animation-duration: 10s;     animation-timeline: box-move; } @scroll-timeline box-move {     source: selector("#g-scroll");     orientation: "vertical"; } @keyframes scale {     0% {         transform: translate(-50%, -50%) scale(10);     }     100% {         transform: translate(-50%, -50%) scale(.5);     } } @keyframes scaleWord {     0% {         transform: translate(-50%, -50%) scale(.5);     }     100% {         transform: translate(calc(-50% - 5000px), -50%) scale(100);     } }

整個動畫需要看懂,其實還是要有一定的功底的。上效果:

利用CSS也能輕松實現超酷炫的轉場動畫!

完整的代碼,你可以戳這里:CodePen Demo – WeGame Animation Demo

這樣,借助強大的 CSS 以及一些有意思的技巧,我們利用純 CSS 實現了這兩個看似非常復雜的轉場動畫效果,并且,這在之前,是完全不可能使用純 CSS 實現的

原文地址:https://segmentfault.com/a/1190000042184211

作者:chokcoco

(學習視頻分享:web前端)

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
国产妓女牲交A毛片| 国精产品一二三产区| 国产精品三级一区二区| 国产睡熟迷奷系列网站| 教室内污辱女教师BD高清在线观看 | 亚洲一区在线曰日韩在线| 亚洲综合色区另类小说| 18禁无码无遮挡H动漫免费看| XX性欧美肥妇精品久久久久久| 粉嫩AV一区二区三区免费观看| 国产精品青草久久福利不卡| 极品粉嫩小泬白浆20P| 麻豆国产在线精品国偷产拍| 人妻有码中文字幕在线| 无码超乳爆乳中文字幕久久| 亚洲精品无码永久中文字幕| 777777亚洲午夜成人| 大量潮喷潮喷极限高H| 国产又色又刺激高潮视频| 里番本子侵犯肉全彩无码| 人妻体内射精一区二区三区| 无码人妻AⅤ一区二区三区用会员| 亚洲大成色WWW永久泡芙| 中文字幕夫の上司に犯新沢平兰| 被公疯狂玩弄的漂亮人妻| 国产精品久久久久精品综合紧| 精品日产一卡2卡三卡4卡自拍| 女人被弄到高潮的免费视频APP| 色欲精品国产一区二区三区AV| 亚洲AV永久精品无码桃色| 最新AV片免费网站入口| 关晓彤露内毛黑森林| 久久国产欧美日韩精品| 人妻少妇无码专视频在线| 亚洲AⅤ精品一区二区三区| …久久精品99久久香蕉国产| 国产福利一区二区三区在线视频| 久久久久久精品免费免费| 日本熟妇色XXXXXBBB日本| 亚洲国产精品无码一区二区三区 | 国产精品偷窥老熟女高潮| 久久香港三级台湾三级播放| 色噜噜狠狠一区二区三区| 亚洲日韩精品无码专区网站 | GAY男同帅哥网站在线观看| 国产精品亚洲专区无码导航| 联系附近成熟妇女| 同性男男黄网站在线观看国外| 一个上面一个下面嘴巴| 国产超碰人人爽人人做人人添| 久久人午夜亚洲精品无码区| 少妇毛又多又黑一区二区| 有人有在线观看的片资源| 国产超碰AV人人做人人爽| 乱码一线二线三线新区破解欧 | 人妻互换精品一区二区| 亚洲美女又黄又爽在线观看| 差差差软件大全APP推荐免费| 久久国产色AV免费看| 色综合久久成人综合网五月| 孕妇特级毛片WW无码内射 | 波多野结衣迅雷种子| 精品亚洲国产成人AV在线| 色综合久久精品亚洲国产消防| 有人有在线观看的片吗WWW| 国产女人18毛片水真多1| 欧美性色XXⅩXXA片HD| 亚洲色精品一区二区三AI女星| 国产92成人精品视频免费| 男女做爰高清免费直播网站| 亚洲A∨精品无码一区二区| 别揉我奶头~嗯~啊~| 久久月本道色综合久久| 亚洲 中文 欧美 日韩 在线| 成 人 A V天堂| 秘密列车动漫在线观看| 亚洲AV综合色区无码另类小说| 插插射啊爱视频日A级| 老太婆BBW搡BBBB搡搡搡搡| 亚洲AV福利天堂一区二区三| 成人污污污WWW网站免费| 蜜桃Av噜噜一区二区三区绯色| 五月丁香伊人久久91视频| 波多野结衣一二三区AV高清| 蜜芽AV在线新地址| 亚洲另类无码专区丝袜| 国产精品美女WWW爽爽爽视频| 人人妻人人添人人爽欧美一区| 中文人妻无码一区二区三区信息| 黑人巨大两根一起挤进| 天堂8中文在线最新版在线| 八戒八戒视频在线WWW观看| 美女脱个精光扒开尿口图片无遮挡| 亚洲AV永久无码精品无码少妇| 给个网站2021年直接进入的| 欧洲免费无码视频在线| 中文精品久久久久人妻| 久久久国产精品ⅤA麻豆百度| 小浪货腿张开水好多呀H| 俄罗斯性孕妇孕交| 日本边添边摸边做边爱小视频| 6080午夜三级中文在线观看| 久久人人爽人人人人爽AV| 亚洲精品97久久中文字幕无码| 国产乱子伦视频一区二区三区| 少妇人妻一级AV片| 成为全校公交车的日常生活| 人妻av无码一区二区| 99精品无人区乱码1区2区3区| 久久亚洲精品中文字幕| 亚洲熟女WWW一区二区三区| 娇妻宾馆被三根粗大的夹击 | 国产午夜成人无码一区二区| 玩弄中国白嫩少妇HD乱| 国产99视频精品免视看7| 色综合久久久无码中文字幕波多| 哺乳挤奶一区二区三区免费看| 欧洲精品免费一区二区三区| A∨色狠狠一区二区三区| 欧美成人精品视频一区二区三区| 坐在根茎写作业好吗| 男人J桶进女人P无遮挡全过程| 50熟妇的长奶头满足了我| 男男无码SM调教GV资源| 97久久精品午夜一区二区| 欧美成人精品视频在线不卡| 99国精产品灬源码168| 欧美ZC0O人与善交| CHINESE树林性BBW| 青青草无码精品伊人久久7| 锕锕锕锕锕~好深啊免费软件 | 国产SM鞭打折磨调教视频| 调教后把奶头拴在跑步机上虐 | 久久综合伊人中文字幕| 中国国语毛片免费观看视频| 美国ZOOM人与ZOOM视频| 80S国产成年女人毛片| 欧美一级 片内射欧美A999| 不屈的儿媳妇电视剧汉语版| 日韩人妻系列无码专区| 成人精品视频一区二区 | 国产成人亚洲综合无码99| 无码人妻AV免费一区二区三区| 国产九九久久99精品影院| 亚洲第一AV导航AV尤物| 久久精品国产亚洲不AV麻豆| 中文精品一卡2卡3卡4卡| 欧美另类视频在线观看| 城中村勾搭老熟女啪啪| 天天躁夜夜躁狠狠是什么心态| 国产六月婷婷爱在线观看| 亚洲AV无码一区二区少妇| 久久AⅤ无码AV高潮AV喷吹| 伊人久久大香线蕉综合影院首页| 美女裸身裸乳免费视频的APP| VIDEOS欧美熟妇高跟| 色欲久久九色一区二区三区| 国产偷国产偷亚洲清高APP| 亚洲人成网77777亚洲色| 免费韩国漫画网站观看| 被义子侵犯的漂亮人妻中字| 我和丰满女教练在线观看| 精品国产AⅤ一区天美传媒| 中国小YOUNV女YOUNV| 日本欧美午夜成人免费观看| 国产乱XXXX搡XXXXX搡| 亚洲人成电影在线观看天堂色| 男人j捅进女人p| 国产97在线 | 中文| 亚洲国产精品成人一区二区在线 | 天堂А√在线地址中文在线| 好紧真爽喷水高潮视频办公室| 曰韩少妇内射免费播放| 日本精品一线二线三线区别在哪里 | 铜铜铜铜铜铜铜铜铜好大好深色| 娇妻出轨哀求高潮喷水| 最新中文字幕AV无码不卡| 熟妇大屁股一区二区三区视频| 精品3D动画肉动漫在线无码| 2018最新国产好看的国产| 色噜噜狠狠色综合网| 极品白嫩的小少妇| CHINESEHD国产精品麻豆| 无码专区亚洲综合另类| 久久亚洲精品无码爱剪辑| ZOOM另一类ZZO0| 性猛交ⅩXXX富婆video| 麻豆网神马久久人鬼片| 高清国产天干天干天干不卡顿| 亚洲男人AV天堂男人社区| 欧美最婬乱婬爆婬牲视| 国产偷国产偷亚洲清高孕妇 | 亚洲精品无码久久| 欧美日韩一区二区三区精品视频 | 给个网站2021年直接进入的| 亚洲清清爽爽AABB| 日本不卡在线视频二区三区| 极品少妇被黑人白浆直流 | 天天躁日日躁狠狠躁婷婷高清| 久久久久久久精品无码Av少妇|