本文实例为大家分享了纯CSS3绘制打火机动画火焰效果的具体代码,供大家参考,具体内容如下
主要涉及到了以下属性:
XML/HTML Code复制内容到剪贴板- <span style="font-family:Comic Sans MS;">animation(webkit-animation),
- @keyframes name (@-webkit-keyframes name),
- transform,
- transform-origin,
- transition,
- box-shadow(spread属性),
- text-shadow
- z-index
- linear-gradient。
- radial-gradient
- background-image
- </span>
首先html代码如下:
- <span style="font-family:Comic Sans MS;"><!DOCTYPE html>
- <html>
- <head>
- <meta charset="UTF-8">
- <title>纯CSS绘制打火机动画火焰特效</title>
- <link rel="stylesheet" href="css/style.css">
- </head>
- <body class="keBody">
- <h1 class="keTitle">纯CSS3绘制打火机动画火焰特效</h1>
- <div class="kePublic">
- <div class="playground">
- <div class="flame"></div>
- <div class="lighterBody">
- <div class="hover">hover me</div>
- </div>
- <div class="lid"></div>
- </div>
- <div class="clear"></div>
- </div>
- </body>
- </html></span>
style.css文件如下:
CSS Code复制内容到剪贴板- <span style="font-family:Comic Sans MS;">@charset "utf-8";
- body{
- margin:0;
- padding:0;
- color:#333;
- text-align:center;
- font:12px "微软雅黑";
- }
- :before,:after{
- position:absolute;
- content:"";
- }
- .keBody{
- background:url(../images/bodyBg.jpg) repeat #333;
- }
- .keTitle{
- height:100px;
- line-height:100px;
- font-size:30px;
- font-family:'微软雅黑';
- color:#fff;
- text-align:center;
- background:url(../images/bodyBg3.jpg) repeat-x bottombottom left;
- font-weight:normal;
- margin-bottom:0;
- }
- .kePublic{
- background:#cccccc;
- padding:50px;
- }
- .playground{
- position:relative;
- width:140px;
- height:400px;
- left:50%;
- margin-left:-70px;
- }
- .flame{
- opacity: 0;
- position: absolute;
- bottombottom: 60%;
- left: 42%;
- width: 14px;
- height: 70px;
- background-color: white;
- border-radius: 100% 100% 0 0;
- box-shadow: 0 0 20px #FFFEF0, 0 0 20px #FFFEE6, 0 0 20px #fefcc9, 10px -10px 30px #feec85, -20px -20px 40px #ffae34, 20px -40px 50px #ec760c, -20px -60px 60px #cd4606, 0 -80px 70px #973716, 10px -90px 80px #451b0e;
- }
- .playground:hover .flame {
- opacity:1;
- transition:opacity 3s linear;
- -webkit-animation:flame 1s infinite linear;
- }
- .playground:hover .lid{
- -webkit-animation:lidoff 1s linear;
- /*把物体动画地从一个地方移动到另一个地方,并让它停留在那里:*/
- -webkit-animation-fill-mode:forwards;
- }
- .lighterBody{
- position:absolute;
- width:140px;
- height:130px;
- top:200px;
- left:0;
- background-image:linear-gradient(to rightright,#959595 0%,#0d0d0d 46%,#010101 50%,#0a0a0a 53%,
- #4e4e4e 76%,#383838 87%,#1b1b1b 100%);
- border-radius:2% 2% 8% 8%;
- box-shadow:inset 0 0 5px 5px #333;
- }
- .lighterBody:before{
- width:47px;
- height:47px;
- top:-50px;
- left: 42px;
- content:"...";
- color:#e6e6e6;
- border-radius:6% 6% 0 0;
- background-image:linear-gradient(to rightright,#f5f5f5 0%,#dbdce2 21%,#b8bac6 49%,#dddfe3 80%,#f5f6f6 100%);
- font-size:30px;
- font-weight:bold;
- letter-spacing:7px;
- line-height:16px;
- text-shadow:0 0 5px black;
- padding-top:3px;
- padding-left:4px;
- }
- .lighterBody:after{
- width:33px;
- height:33px;
- background-image:radial-gradient(ellipse at center,#7d737d 0%,#0e0e0e 100%);
- border-radius:100%;
- top:-33px;
- left:10px;
- box-shadow:inset 0 0 1px 2px gray;
- }
- .lid{
- z-index:2;
- position:absolute;
- width:140px;
- height:75px;
- top:125px;
- left:0;
- background:linear-gradient(to rightright,#959595 0%,#0d0d0d 46%, #010101 50%, #0a0a0a 53%, #4e4e4e 76%, #383838 87%, #1b1b1b 100%);
- border-radius:8% 8% 2% 2%;
- box-shadow:inset 0 0 5px 5px #333;
- /*border-bottom:3px solid #f2f2f2;*/
- }
- .lid:before{
- width:10px;
- height:10px;
- top:70px;
- left:133px;
- background-image:radial-gradient(ellipse at center, #959595 0%, #0d0d0d 46%, #010101 50%, #0a0a0a 53%, #4e4e4e 76%, #383838 87%, #1b1b1b 100%);
- border-radius:100%;
- }
- .hover{
- z-index:1;
- text-align:center;
- margin-top:30%;
- color:rgba(255,255,255,0.9);
- text-shadow:0 1px 1px rgba(0,0,0,0.8);
- font: 20px "微软雅黑";
- }
- .hover:before{
- content:"";
- z-index:1;
- width:0;
- height:0;
- top:-50px;
- left:20px;
- border-bottom:35px solid #f2f2f2;
- /*border-left:10px solid transparent;*/
- }
- @-webkit-keyframes flame{
- 0%{
- height:70px;
- transform:skewY(0deg);
- border-radius:100% 100% 0 0;
- }
- 25%{
- height:60px;
- transform:skewY(40deg);
- border-radius:10% 100% 0 0;
- }
- 60%{
- height:65px;
- transform:skewY(-20deg);
- border-radius:90% 10% 0 0;
- }
- 70%{
- height:50px;
- transform:skewY(10deg);
- border-radius:10% 100% 0 0;
- }
- 100%{
- height:70px;
- tranform:skewY(0deg);
- }
- }
- @-webkit-keyframes lidoff{
- from{
- transform:rotate(0deg);
- transform-origin:100% 100%;
- }
- to{
- transform:rotate(130deg);
- transform-origin:100% 100%;
- }
- }</span>
初始照片:
动态照片
动画效果主要有两个,一是当鼠标悬停在“hover me”上面时打火机盖子打开的情形,由下面的动画代码实现:
XML/HTML Code复制内容到剪贴板- <span style="font-family:Comic Sans MS;font-size:12px;">@-webkit-keyframes lidoff{ 注意这里要加上-webkit-
- from{
- transform:rotate(0deg);
- transform-origin:100% 100%;
- }
- to{
- transform:rotate(130deg);
- transform-origin:100% 100%;
- }
- }
- </span>
第二个动画是蜡烛灯光效果的实现:蜡烛由按变量是由transition:opacity 3s linear; 实现的,
蜡烛灯光的随风摆动效果是由下面的代码实现的:
- <span style="font-family:Comic Sans MS;font-size:12px;">@-webkit-keyframes lidoff{
- from{
- transform:rotate(0deg);
- transform-origin:100% 100%;
- }
- to{
- transform:rotate(130deg);
- transform-origin:100% 100%;
- }
- </span>
将打火机盖与躯干分离的效果是由:box-shadow:inset 0 0 5px 5px #333; 主要是这里的inset(注意不要写成了insert)实现的。
当打火机打开时出现的圆球和白色的小正方形,是由:after :before 配合z-index实现的效果。
下面来介绍通过这个例子我的学到的几个属性需要注意的地方。
transform-origin: 默认的初始位置是图像的中心,100% 100%相当于 right bottom. 0% 0%相当于 left top.
before 和:after : 注入的内容是有关联的目标元素的字子元素,但它会被置于这个元素任何内容的“前” 或"后"。插入的内容在页面的源码里是看不见的,只能在css里看见。同时插入的元素在默认情况是内联元素。因此,为了给插入的元素赋予高度、填充、边距等等,通常必须显示的定义一个块级元素(display:block)。
此外,虽然可能不会插入任何内容,但是content必须写上,如果不插入任何内容,那么content写成 content:"";
IE6和IE7不兼容这两个为元素
伪元素(双冒号),css3中的伪类是(单冒号)
animation-fill-mode: none|forwards|backwards|both|initial|inherit;
规定当动画不播放时(当动画完成时,或当动画有一个延迟未开始播放时),要应用到元素的样式。
background-image:解决了div只能设置一个背景的问题,使一个div可以设置多个背景图片。
box-shadow:一个经常被遗忘的参数--spread(扩展阴影半径),这个曾经被遗忘的spread改变阴影的大小---其值可以是正负值,如果值为正,则整个阴影都延展扩大,反之是负值,则缩小。有了这个参数后可以使用box-shadow像photoshop中的阴影工作一样,制作单边阴影效果。这里注意一点,这个扩展阴影值需要和阴影模糊半径配合使用,一般情况是“扩展阴影半径一般设置为和模糊半径大小,并去其负值”
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
CSS3,打火机,火焰
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新动态
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]