摘要:年終活動動畫總結戳這里采用的插件,即可滿足大多數,手機的兼容性問題。人移動切換,添加類控制移動和暫停,以及切換背景人物。監(jiān)聽動畫結束時機橋的出現(xiàn)配合屬性實現(xiàn)。不添加會影響自身頁數的判斷動畫總結別人寫的真牛自己只會。
年終活動h5動畫總結
戳這里----♂--github--
css3 + react-id-swiper + react + redux + saga1. 動畫相關主要內容:
采用postcss的Autoprefixer插件,即可滿足大多數oppo,vivo手機的兼容性問題。
流星
閃爍星星
字的晃動
人的移動(動畫 + 監(jiān)聽動畫結束時間)
橋的鋪墊
開啟旅程按鈕縮放
旋轉(+ 兼容)
react-id-swiper
swiper配合css3實現(xiàn)切換
2. css3動畫語法animation
animation-name animation-duration animation-timing-function 速度曲線 animation-delay animation-iteration-count animation-direction play-state fill-mode
transform
transform 屬性向元素應用 2D 或 3D 轉換。該屬性允許我們對元素進行旋轉、縮放、移動或傾斜。
其中 transform-origin (屬性改變被轉換元素的中心)。
transition
三者區(qū)別: animation 動畫,關鍵幀,往復性。 transition 過渡, 屬性,觸發(fā)動作,一過性。 transform 變換, 復雜的變換參數。3. 示例 https://github.com/hytStart/R...
流星
改變位置translate3d,透明度opacity和大小scale。
流星尾巴采用偽元素元素:after旋轉-45deg(旋轉基點為左transform-origin: left;);采用border可以實現(xiàn),靠近頭部越亮,靠近尾部越暗。
.star { display: block; width: 5px; height: 5px; border-radius: 50%; background: #FFF; top: 10px; left: 200px; position: relative; animation: star-ani 6s infinite ease-out; box-shadow: 0 0 5px 5px rgba(255, 255, 255, .3); opacity: 1; } .star:after { content: ""; display: block; top: 0px; left: 40%; border: 0px solid #fff; border-width: 0px 90px 2px 90px; border-color: transparent transparent transparent rgba(255, 255, 255, .3); transform: rotate(-45deg) translate3d(1px, 3px, 0); box-shadow: 0 0 1px 0 rgba(255, 255, 255, .1); transform-origin: left; } @keyframes star-ani { 0% { opacity: 0; transform: scale(0) rotate(0) translate3d(0, 0, 0); } 50% { opacity: 1; transform: scale(1) rotate(0) translate3d(-100px, 100px, 0); } 100% { opacity: 0; transform: scale(1) rotate(0) translate3d(-200px, 200px, 0); } }
閃爍星星
改變透明度
.shine { background: url("../../../../images/action/icon-star1.png") no-repeat center; background-size: 100%; width: 30px; height: 40px; position: absolute; top: 90px; left: 100px; opacity: 0; animation: opacity-change 0.5s ease-in-out infinite; } @keyframes opacity-change { 0% { opacity: 0; } 50% { opacity: 1; } 100% { opacity: 0; } }
字
分為兩段動畫,下降和上升。translateY改變即可。
.text-item-0 { position: absolute; width: 25px; height: 75px; top: 60px; left: 100px; background: url("../../../../images/action/S-start.png") no-repeat center; background-size: 100%; animation: letter-0 1.5s ease-in-out both, letter-0-1 2.0s ease-in-out 1.5s both; } @keyframes letter-0 { 0% { transform: translateY(0) } 50% { transform: translateY(80px) } 100% { transform: translateY(0px) } } @keyframes letter-0-1 { 0% { opacity: 1; } 100% { top: -80px; opacity: 0; } }
人移動
切換dom,添加類控制移動和暫停,以及切換背景人物。監(jiān)聽animationend事件。
jsx { peopleMove ?{ this.start2 = start2 }} /> : } css .people { width: 20px; height: 64px; position: absolute; left: 10px; top: 130px; background: url("../../../../images/action/people.png") no-repeat center; background-size: 100%; opacity: 0; animation: peopleUp 1s ease-in-out 0.5s both; } .people_move { background: url("../../../../images/action/people_moveleft.gif"); background-size: 100% 100%; background-position: center; background-repeat: no-repeat; width: 20px; height: 64px; position: absolute; left: 10px; top: 130px; opacity: 1; animation: PeopleMove 1.5s linear 0s both; } .people_paused { width: 20px; height: 64px; background: url("../../../../images/action/people.png"); background-size: 100% 100%; background-position: center; background-repeat: no-repeat; animation-play-state: paused; } @keyframes peopleUp { 0% { opacity: 0; } 100% { opacity: 1; } } @keyframes PeopleMove { 0% { left: 10px; top: 130px; } 100% { top: 20px; left: 180px; background-size: 100% 100%; background-position: center; background-repeat: no-repeat; } } // 監(jiān)聽動畫結束時機 componentDidUpdate() { const { peopleMove } = this.state if (peopleMove) { this.start2.addEventListener("animationend", this.end) this.start2.addEventListener("webkitAnimationEnd", this.end) this.start2.addEventListener("mozAnimationEnd", this.end) this.start2.addEventListener("oAnimationEnd", this.end) } }橋的出現(xiàn)
配合background-size: cover;屬性實現(xiàn)。.brige { width: 0px; background: url("../../../../images/action/bridge.png"); background-size: cover; background-repeat: no-repeat; height: 100px; position: absolute; top: 40px; left: 30px; animation: BridgeFadeIn 3s linear both; opacity: 0; } @keyframes BridgeFadeIn { 0% { width: 0px; opacity: 0; } 100% { width: 200px; opacity: 1; } }漸變大(開始旅程)
利用transform scale2D 縮放轉換。.icon-ciecle { display: block; position: absolute; left: 100px; top: 80px; width: 30px; height: 30px; background: url("../../../../images/action/icon-light.png") no-repeat center; background-size: 100%; animation: warn 1.2s ease-in-out 0s infinite both; } @keyframes warn { 0% { transform: scale(0.1); opacity: 0.0; } 25% { transform: scale(0.2); opacity: 0.3; } 50% { transform: scale(0.4); opacity: 0.5; } 75% { transform: scale(0.6); opacity: 0.7; } 100% { transform: scale(0.8); opacity: 0.0; } }旋轉
ios的animation-play-state: paused;不起作用,且animation動畫不可寫在新增類里,必須寫在一個類里。(測試中發(fā)現(xiàn),這里有疑問。).music_img { width: 40px; height: 40px; display: block; position: absolute; left: 100px; top: 80px; animation: rotating 3s linear infinite; animation-play-state: running; } .rotate-pause { animation-play-state: paused; } @keyframes rotating { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }react-id-swiper
Swiper的react版本,基本api都支持,具實驗目測相當于Swiper v4。
不一定通過api。也可以通過重寫css實現(xiàn)。
重寫css切換效果的話,會影響它本身的動畫效果,所以可通過添加不可滑動來控制。
1. .swiper-wrapper { transition-delay: 1.6s; } 2. noSwiping: true, noSwipingClass: "stop-swiping",Swiper實現(xiàn)的迷宮切換
1.swiper的effect屬性與控制背景圖片的opacity,利用時間差實現(xiàn)最終效果。包括迷宮的切換,背包男的出現(xiàn)與消失,彈窗的出現(xiàn)與消失。
2.swiper屬性的activeIndex,可以得到滑動到第幾頁,通過改變dom或者改變類,控制第幾頁動畫的發(fā)生。// 根據activeIndex拿到的頁數,控制該頁數state的改變,通過切換dom和添加類的方式,達到進場與退場的動畫效果。 // 添加類stop-swiping控制不可滑動,動畫完成后,才可繼續(xù)滑動下一頁。 const mazeStyle = classNames({ [styles["maze-1"]]: true, [styles["maze-out"]]: firstMazeOut, }) const peopleStyle = classNames({ [styles["people-1"]]: true, [styles["people-out"]]: firstMazeOut, }) const popCardStyle = classNames({ [styles["pop-card-container"]]: true, [styles["pop-card-out"]]: firstMazeOut, }) { firstMazeIn ?4. 動畫總結: // 不添加會影響swiper自身頁數的判斷 } 別人寫的真牛X,自己只會opacity,translate。5. 待完善html2canvas
資源加載
jsbridge使用與注意事項
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/114406.html
摘要:年終活動動畫總結戳這里采用的插件,即可滿足大多數,手機的兼容性問題。人移動切換,添加類控制移動和暫停,以及切換背景人物。監(jiān)聽動畫結束時機橋的出現(xiàn)配合屬性實現(xiàn)。不添加會影響自身頁數的判斷動畫總結別人寫的真牛自己只會。 年終活動h5動畫總結 戳這里----♂--github-- css3 + react-id-swiper + react + redux + saga 采用postcss...
摘要:由于初版需求及開發(fā)工作都沒有參與,在接手項目后過了遍前端結構發(fā)現(xiàn)所有交互及組件都是現(xiàn)擼,并未使用市面上已有的優(yōu)秀前端框架從我個人角度理解上出發(fā),后續(xù)需求變更中當需要實現(xiàn)某些常用組件樣式或交互時,基本上都需要現(xiàn)擼或者尋找合適的組件。 2016悄無聲息的過去了,再過不久便是農歷新年 這幾天相對清閑梳理了一下去年所做的工作,希望在新的一年能發(fā)展的更好 今年一共研發(fā)或升級了五款產品:合伙人、奪...
摘要:為了實現(xiàn)物體隨機出現(xiàn)的效果,讓每個物體隨機多少秒后開始出現(xiàn)最后一個物體出現(xiàn)完,多少秒后出現(xiàn)結束畫面等等,需要理清楚各個定時器的關系,并對其添加語義化良好的標記,及時對未完結的定時器進行清除,防止定時器帶來的意想不到的問題。 快到年終的時候做了一個以游戲形式展示的h5活動頁,第一次嘗試使用js寫小游戲,很有趣的過程,很寶貴的經驗。 效果圖 直接上個效果的gif圖,游戲的一小部分效果,錄出...
閱讀 3812·2023-04-26 02:07
閱讀 3684·2021-10-27 14:14
閱讀 2871·2021-10-14 09:49
閱讀 1635·2019-08-30 15:43
閱讀 2628·2019-08-29 18:33
閱讀 2380·2019-08-29 17:01
閱讀 924·2019-08-29 15:11
閱讀 601·2019-08-29 11:06