這篇文章主要介紹了CSS3動畫製作的簡單範例,特別是像文中這樣實現一個動態表情的情況是非常給力的~需要的朋友可以參考下
CSS3 大大強化了製作動畫的能力,但是如果要做圖案比較複雜的動畫,選擇GIF 依然是一個不錯的選擇。今天要來跟大家介紹一個使用 CSS animation 來配合雪碧圖(CSS sprite)來製作動畫的方法,可以做出類似 GIF 動畫的效果。
CSS3 Animation steps函數
首先看看,CSS3 animation的相容性。可以看到基本上主流瀏覽器都支援了 animation 屬性,chrome、safari、opera和行動端的瀏覽器帶上前綴就可以支援。
利用雪碧圖來製作動畫使用了 CSS3 Animation 裡面的一個重要的函數 steps。
animation 本身是一個複合的屬性,它包含了animation-name,animation-timing-function,animation-iteration-count,animation-direction,animation-play-state,animation-fill-mode 六個屬性。
steps 就是屬於 animation-timing-function 中的一個函數。
animation-timing-function 平常我們用的比較多的是預設的一些動畫曲線值 ease、ease-in 等等。而 steps 則可以由我們控制動畫分成多少個部分進行。
steps(n,[start|end]) 傳入一到兩嘅個參數,第一個參數意思是把動畫分成 n 等分,然後動畫就會平均運作。第二個參賽預設值是 start 表示從動畫的開頭開始運行,相反,end 就表示從動畫的結尾開始運行。
因此,我們利用雪碧圖和steps 函數製作動畫的原理就是,雪碧圖包含了動畫圖片的每一幀,然後利用steps 函數確定固定時間內動畫運行的部分等於動畫的幀數,從而實現動畫效果。
動畫實例
用猥瑣的兔斯基做例子╮( ̄▽ ̄")╭
首先我們要切圖,把動畫的每一幀切成這樣的圖:
切圖如果大家不想折騰,推薦在線合併雪碧圖的工具。
然後寫keyframes
@-webkit-keyframes tuski { 0% { background-position:0; } 100% { background-position: -576px 0; } } @-moz-keyframes tuski { 0% { background-position:0; } 100% { background-position: -576px 0; } } @keyframes tuski { 0% { background-position:0; } 100% { background-position: -576px 0; } }
呼叫動畫
#tuski { -webkit-animation: tuski .5s steps(12) infinite; -moz-animation: tuski .5s steps(12) infinite; animation: tuski .5s steps(12) infinite; }
與GIF 相比,這種動畫可以讓我們手動調整動畫運行的速度。
大功告成。
以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!
#相關推薦:
######################### ####關於css過渡和3D效果的簡單實作###############用CSS3繪製打火機動畫火焰的效果############## #######
以上是關於使用CSS3製作動畫的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

两种方法:1、利用display属性,只需给元素添加“display:none;”样式即可。2、利用position和top属性设置元素绝对定位来隐藏元素,只需给元素添加“position:absolute;top:-9999px;”样式。

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯CSS也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

实现方法:1、使用“:active”选择器选中鼠标点击图片的状态;2、使用transform属性和scale()函数实现图片放大效果,语法“img:active {transform: scale(x轴放大倍数,y轴放大倍数);}”。

自适应布局又称“响应式布局”,是指可以自动识别屏幕宽度、并做出相应调整的网页布局;这样的网页能够兼容多个不同的终端,而不是为每个终端做一个特定的版本。自适应布局是为解决移动端浏览网页而诞生的,能够为使用不同终端的用户提供很好的用户体验。

css3中的动画效果有变形;可以利用“animation:动画属性 @keyframes ..{..{transform:变形属性}}”实现变形动画效果,animation属性用于设置动画样式,transform属性用于设置变形样式。

在css3中,可以利用“animation-timing-function”属性设置动画旋转速度,该属性用于指定动画将如何完成一个周期,设置动画的速度曲线,语法为“元素{animation-timing-function:速度属性值;}”。

css3线性渐变可以实现三角形;只需创建一个45度的线性渐变,设置渐变色为两种固定颜色,一个是三角形的颜色,另一个为透明色即可,语法“linear-gradient(45deg,颜色值,颜色值 50%,透明色 50%,透明色 100%)”。

本篇文章带大家一起深入了解一下CSS3中的新特性::target-text 选择器,聊聊该选择器的作用和使用方法,希望对大家有所帮助!


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

Atom編輯器mac版下載
最受歡迎的的開源編輯器

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Dreamweaver Mac版
視覺化網頁開發工具