纯css3制作煽动翅膀的蝴蝶的示例


Posted in HTML / CSS onApril 23, 2018

纯css3制作煽动翅膀的蝴蝶,先看效果

纯css3制作煽动翅膀的蝴蝶的示例

怎么样,效果还不错吧

上代码:

html

<div id="butterfly">
    <div class="leftSide"></div>
    <div class="body"></div>
    <div class="rightSide"></div>
</div>

css

body{
            background: url("./images/bg.jpg") no-repeat;
        }
        #butterfly{
            width: 600px;
            height: 500px;
            position: relative;
            transform: scale(0.35);
            transform-style: preserve-3d;
        }
        .leftSide{
            width: 267px;
            height: 421px;
            background: url("./images/leftSide.png") no-repeat;
            position: absolute;
            left: 26px;
            top: 40px;
            animation: left 2s infinite;
            z-index: 9999;
        }
        @keyframes left {
            0%{
                transform: rotateY(0deg);
                transform-origin: right center;
                perspective: 201px;

            }
            50%{
                transform: rotateY(70deg);
                transform-origin: right center;
                perspective: 201px;

            }
            100%{
                transform: rotateY(0deg);
                transform-origin: right center;
                perspective: 201px;
            }
        }
        @keyframes right {
            0%{
                transform: rotateY(0);
                transform-origin: left center;
                perspective: 201px;

            }
            50%{
                transform: rotateY(-70deg);
                transform-origin: left center;
                perspective: 201px;

            }
            100%{
                transform: rotateY(0);
                transform-origin: left center;
                perspective: 201px;

            }
        }
        .body{
            width: 152px;
            height: 328px;
            background: url("./images/body.png") no-repeat;
            position: absolute;
            margin: auto;
            left: 0;
            right: 0;
            bottom: 0;
            top: 0;
            z-index: 9999;
        }
        .rightSide{
            width: 284px;
            height: 460px;
            background: url("./images/rightSide.png") no-repeat;
            position: absolute;
            right: 26px;
            top: 58px;
            animation: right 2s infinite;
            z-index: 9999;
        }

在这之前介绍几个css属性;

@keyframes

  1. 通过 @keyframes 规则,我们能够创建动画
  2. 创建动画的原理是,将一套 CSS 样式逐渐变化为另一套样式
  3. 以百分比来规定改变发生的时间,或者通过关键词 "from" 和 "to",等价于 0% 和 100%。
  4. 0% 是动画的开始时间,100% 动画的结束时间

transform: rotateY()

  1. transform 属性向元素应用 2D 或 3D 转换。该属性允许我们对元素进行旋转、缩放、移动或倾斜。
  2. rotateY()定义沿着 Y 轴的 3D 旋转。

纯css3制作煽动翅膀的蝴蝶的示例

这张图很直观的说明了xyz轴,其实学过3DS MAX这类3d建模软件的同学应该更为熟悉这个3轴的指向。

实现思路:先用子绝父相将左翅膀,右翅膀,和身体进行绝对定位,拼合在一起,然后利用transform的rotateY使其沿y轴旋转,旋转这里使用@keyframe动画,然后重复动作。

还要重点介绍下transform-style: preserve-3d;这个属性,w3c 的说明是 使被转换的子元素保留其 3D 转换。也就是所有子元素在3D空间中呈现,相反设置为flat的话,则所有子元素在2D空间中呈现

demo下载地址

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
CSS中垂直居中的简单实现方法
Jul 06 HTML / CSS
CSS3 text shadow字体阴影效果
Jan 08 HTML / CSS
CSS3 mask 遮罩的具体使用方法
Nov 03 HTML / CSS
HTML5 Canvas 起步(1) - 基本概念
May 12 HTML / CSS
HTML5 canvas基本绘图之文字渲染
Jun 27 HTML / CSS
HTML5 WebSocket实现点对点聊天的示例代码
Jan 31 HTML / CSS
html5 canvas的绘制文本自动换行的示例代码
Sep 17 HTML / CSS
html5 canvas绘制网络字体的常用方法
Aug 26 HTML / CSS
详解如何获取localStorage最大存储大小的方法
May 21 HTML / CSS
Canvas波浪花环的示例代码
Aug 21 HTML / CSS
纯html+css实现Element loading效果
Aug 02 HTML / CSS
使用canvas对video视频某一刻截图功能
Sep 25 HTML / CSS
CSS3使用transition属性实现过渡效果
Apr 18 #HTML / CSS
CSS3 二级导航菜单的制作的示例
Apr 02 #HTML / CSS
CSS3实现全景图特效示例代码
Mar 26 #HTML / CSS
css3新单位vw、vh的使用教程
Mar 23 #HTML / CSS
巧用CSS3的calc()宽度计算做响应模式布局的方法
Mar 22 #HTML / CSS
利用css3径向渐变做一张优惠券的示例
Mar 22 #HTML / CSS
css3 边框、背景、文本效果的实现代码
Mar 21 #HTML / CSS
You might like
用PHP调用Oracle存储过程
2006/10/09 PHP
深入了解php4(1)--回到未来
2006/10/09 PHP
PHP 编程安全性小结
2010/01/08 PHP
php中使用redis队列操作实例代码
2013/02/07 PHP
JS对外部文件的加载及对IFRMAME的加载的实现,当加载完成后,指定指向方法(方法回调)
2011/07/04 Javascript
用javascript关闭本窗口不弹出询问框的方法
2014/09/12 Javascript
javascritp添加url参数将参数加入到url中
2014/09/25 Javascript
jQuery实现数秒后自动提交form的方法
2015/03/05 Javascript
JS实现定时自动关闭DIV层提示框的方法
2015/05/11 Javascript
JS实现的自定义右键菜单实例二则
2015/09/01 Javascript
js接收并转化Java中的数组对象的方法
2016/08/11 Javascript
AngularJS的ng Http Request与response格式转换方法
2016/11/07 Javascript
JavaScript基于面向对象实现的猜拳游戏
2018/01/03 Javascript
React 路由懒加载的几种实现方案
2018/10/23 Javascript
基于javascript canvas实现五子棋游戏
2020/07/08 Javascript
vue界面发送表情的实现代码
2020/09/11 Javascript
[08:02]DOTA2牵红线 zhou神抱得美人归
2014/03/22 DOTA
[59:32]Liquid vs Fnatic 2019国际邀请赛淘汰赛败者组BO1 8.20.mp4
2020/07/19 DOTA
在Python中定义和使用抽象类的方法
2016/06/30 Python
Python之父谈Python的未来形式
2016/07/01 Python
python读取和保存图片5种方法对比
2018/09/12 Python
Python爬虫图片懒加载技术 selenium和PhantomJS解析
2019/09/18 Python
wxpython多线程防假死与线程间传递消息实例详解
2019/12/13 Python
为什么python比较流行
2020/06/19 Python
Python 如何定义匿名或内联函数
2020/08/01 Python
CSS 3.0文字悬停跳动特效代码
2020/10/26 HTML / CSS
巴西购物网站:Estrela10
2018/12/13 全球购物
瑞典耳机品牌:URBANISTA
2019/12/03 全球购物
海南地接欢迎词
2014/01/14 职场文书
拔河比赛口号
2014/06/10 职场文书
幼儿园爱国卫生月活动总结
2014/06/30 职场文书
企业安全生产月活动总结
2014/07/05 职场文书
保护校园环境倡议书
2015/04/28 职场文书
《火烧云》教学反思
2016/02/23 职场文书
高效课堂教学反思
2016/02/24 职场文书
Springboot配置suffix指定mvc视图的后缀方法
2021/07/03 Java/Android