逼真的HTML5樹葉飄落動畫
本文由碼農網 – 小峰原創,轉載請看清文末的轉載要求,歡迎參與我們的付費投稿計劃!
這是一款基於HTML5的樹葉飄落動畫,樹葉都是圖片,並非CSS3繪製,但是樹葉飄落的動畫效果非常逼真。這款HTML5樹葉飄落動畫是基於webkit核心的,也就是說要在webkit核心的瀏覽器上才能使用這款動畫。
HTML程式碼
<div id="container"> <!-- The container is dynamically populated using the init function in leaves.js --> <!-- Its dimensions and position are defined using its id selector in leaves.css --> <div id="leafContainer"></div> <!-- its appearance, dimensions, and position are defined using its id selector in leaves.css --> <div id="message"> <em>這是基於webkit的落葉動畫</em> </div> </div>
CSS程式碼
#container { position: relative; height: 700px; width: 500px; margin: 10px auto; overflow: hidden; border: 4px solid #5C090A; background: #4E4226 url('images/backgroundLeaves.jpg') no-repeat top left; } /* Defines the position and dimensions of the leafContainer div */ #leafContainer { position: absolute; width: 100%; height: 100%; } /* Defines the appearance, position, and dimensions of the message div */ #message { position: absolute; top: 160px; width: 100%; height: 300px; background:transparent url('images/textBackground.png') repeat-x center; color: #5C090A; font-size: 220%; font-family: 'Georgia'; text-align: center; padding: 20px 10px; -webkit-box-sizing: border-box; -webkit-background-size: 100% 100%; z-index: 1; } p { margin: 15px; } a { color: #5C090A; text-decoration: none; } /* Sets the color of the "Dino's Gardening Service" message */ em { font-weight: bold; font-style: normal; } .phone { font-size: 150%; vertical-align: middle; } /* This CSS rule is applied to all div elements in the leafContainer div. It styles and animates each leafDiv. */ #leafContainer > div { position: absolute; width: 100px; height: 100px; /* We use the following properties to apply the fade and drop animations to each leaf. Each of these properties takes two values. These values respectively match a setting for fade and drop. */ -webkit-animation-iteration-count: infinite, infinite; -webkit-animation-direction: normal, normal; -webkit-animation-timing-function: linear, ease-in; } /* This CSS rule is applied to all img elements directly inside div elements which are directly inside the leafContainer div. In other words, it matches the 'img' elements inside the leafDivs which are created in the createALeaf() function. */ #leafContainer > div > img { position: absolute; width: 100px; height: 100px; /* We use the following properties to adjust the clockwiseSpin or counterclockwiseSpinAndFlip animations on each leaf. The createALeaf function in the Leaves.js file determines whether a leaf has the clockwiseSpin or counterclockwiseSpinAndFlip animation. */ -webkit-animation-iteration-count: infinite; -webkit-animation-direction: alternate; -webkit-animation-timing-function: ease-in-out; -webkit-transform-origin: 50% -100%; } /* Hides a leaf towards the very end of the animation */ @-webkit-keyframes fade { /* Show a leaf while into or below 95 percent of the animation and hide it, otherwise */ 0% { opacity: 1; } 95% { opacity: 1; } 100% { opacity: 0; } } /* Makes a leaf fall from -300 to 600 pixels in the y-axis */ @-webkit-keyframes drop { /* Move a leaf to -300 pixels in the y-axis at the start of the animation */ 0% { -webkit-transform: translate(0px, -50px); } /* Move a leaf to 600 pixels in the y-axis at the end of the animation */ 100% { -webkit-transform: translate(0px, 650px); } } /* Rotates a leaf from -50 to 50 degrees in 2D space */ @-webkit-keyframes clockwiseSpin { /* Rotate a leaf by -50 degrees in 2D space at the start of the animation */ 0% { -webkit-transform: rotate(-50deg); } /* Rotate a leaf by 50 degrees in 2D space at the end of the animation */ 100% { -webkit-transform: rotate(50deg); } } /* Flips a leaf and rotates it from 50 to -50 degrees in 2D space */ @-webkit-keyframes counterclockwiseSpinAndFlip { /* Flip a leaf and rotate it by 50 degrees in 2D space at the start of the animation */ 0% { -webkit-transform: scale(-1, 1) rotate(50deg); } /* Flip a leaf and rotate it by -50 degrees in 2D space at the end of the animation */ 100% { -webkit-transform: scale(-1, 1) rotate(-50deg); } }
JavaScript程式碼
/* Define the number of leaves to be used in the animation */ const NUMBER_OF_LEAVES = 30; /* Called when the "Falling Leaves" page is completely loaded. */ function init() { /* Get a reference to the element that will contain the leaves */ var container = document.getElementById('leafContainer'); /* Fill the empty container with new leaves */ for (var i = 0; i < NUMBER_OF_LEAVES; i++) { container.appendChild(createALeaf()); } } /* Receives the lowest and highest values of a range and returns a random integer that falls within that range. */ function randomInteger(low, high) { return low + Math.floor(Math.random() * (high - low)); } /* Receives the lowest and highest values of a range and returns a random float that falls within that range. */ function randomFloat(low, high) { return low + Math.random() * (high - low); } /* Receives a number and returns its CSS pixel value. */ function pixelValue(value) { return value + 'px'; } /* Returns a duration value for the falling animation. */ function durationValue(value) { return value + 's'; } /* Uses an img element to create each leaf. "Leaves.css" implements two spin animations for the leaves: clockwiseSpin and counterclockwiseSpinAndFlip. This function determines which of these spin animations should be applied to each leaf. */ function createALeaf() { /* Start by creating a wrapper div, and an empty img element */ var leafDiv = document.createElement('div'); var image = document.createElement('img'); /* Randomly choose a leaf image and assign it to the newly created element */ image.src = 'images/realLeaf' + randomInteger(1, 5) + '.png'; leafDiv.style.top = "-100px"; /* Position the leaf at a random location along the screen */ leafDiv.style.left = pixelValue(randomInteger(0, 500)); /* Randomly choose a spin animation */ var spinAnimationName = (Math.random() < 0.5) ? 'clockwiseSpin' : 'counterclockwiseSpinAndFlip'; /* Set the -webkit-animation-name property with these values */ leafDiv.style.webkitAnimationName = 'fade, drop'; image.style.webkitAnimationName = spinAnimationName; /* Figure out a random duration for the fade and drop animations */ var fadeAndDropDuration = durationValue(randomFloat(5, 11)); /* Figure out another random duration for the spin animation */ var spinDuration = durationValue(randomFloat(4, 8)); /* Set the -webkit-animation-duration property with these values */ leafDiv.style.webkitAnimationDuration = fadeAndDropDuration + ', ' + fadeAndDropDuration; var leafDelay = durationValue(randomFloat(0, 5)); leafDiv.style.webkitAnimationDelay = leafDelay + ', ' + leafDelay; image.style.webkitAnimationDuration = spinDuration; // add the <img> to the <div> leafDiv.appendChild(image); /* Return this img element so it can be added to the document */ return leafDiv; } /* Calls the init function when the "Falling Leaves" page is full loaded */ window.addEventListener('load', init, false);
本文連結:http://www.codeceo.com/article/html5-leaf-animation.html
本文作者:碼農網 – 小峰
[ 原創作品,轉載必須在正文中標註並保留原文連結和作者等資訊。]
相關文章
- 基於HTML5+Webkit實現樹葉飄落動畫HTMLWebKit動畫
- html5 飄雪花動畫(增加背景音樂)HTML動畫
- canvas實現的雪花飄落效果Canvas
- jQuery雪花飄落效果程式碼例項jQuery
- jquery動態生成元素並飄落效果jQuery
- canvas繪製雪花飄落效果程式碼例項Canvas
- canvas實現的雪花飄落效果程式碼例項Canvas
- <轉>cocos2d-x學習筆記(五)模擬樹葉飄落效果的實現(精靈旋轉、翻轉、鐘擺運動等綜合運用)筆記
- 逼真的HTML5 3D水波動畫 可多視角瀏覽HTML3D動畫
- js純程式碼為網站站點新增雪花飄落效果JS網站
- Android自定義View——從零開始實現雪花飄落效果AndroidView
- 讓雲朵飄,微信小程式animation迴圈動畫微信小程式動畫
- 部落格園美化-隨季節變化實現不同的飄落效果
- Android 使用graphics.Camera類實現自定義旋轉飄落Android
- 【動畫消消樂】HTML+CSS 白雲飄動效果 072動畫HTMLCSS
- 872. 葉子相似的樹
- P8844 [傳智杯 #4 初賽] 小卡與落葉
- HTML5動畫API—— requestAnimationFrameHTML動畫APIrequestAnimationFrame
- HTML5 小動畫例子HTML動畫
- 北美電商真的落後於淘寶?亞馬遜爸爸表示不服!亞馬遜
- 【動畫】看動畫輕鬆理解「Trie樹」動畫
- 紅旗飄飄——中線操作技巧之七,什麼是紅旗飄飄
- 二叉樹葉子個數二叉樹
- HTML5部落格資源精選HTML
- HTML5七大優勢“逼宮”APPHTMLAPP
- 11 個 HTML5 動畫工具HTML動畫
- 10 招動畫效果讓你的 App 更有逼格動畫APP
- P8844 [傳智杯 #4 初賽] 小卡與落葉 題解
- 樹莓派2.0,是真的酷樹莓派
- HTML5模擬齒輪動畫HTML動畫
- Kaggle樹葉分類Leaves Classify總結
- php短視訊原始碼,點贊時會有大拇指動畫飄起PHP原始碼動畫
- 飄雪動畫秀3.02註冊演算法分析! (11千字)動畫演算法
- 樹莓派提高shell逼格oh-my-zsh樹莓派
- 超實用的jQuery百葉窗焦點圖動畫jQuery動畫
- html5 學習-3d動畫HTML3D動畫
- 9個最新最酷的HTML5動畫HTML動畫
- Android技能樹 — 動畫小結Android動畫