吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 3592|回复: 6
收起左侧

[其他转载] CSS图片翻转动画技术详解

[复制链接]
daxiafengyun 发表于 2014-12-1 08:17
本帖最后由 daxiafengyun 于 2014-12-1 08:25 编辑

CSS图片翻转动画技术详解

因为不断有人问我,现在我补充一下:IE是支持这种技术的!尽管会很麻烦。需要做的是旋转front和back元素,而不是旋转整个容器元素。如果你使用的是最新版的IE,可以忽略这一节。IE10+是支持的,IE9完全不支持CSS动画。


CSS动画非常的有趣;这种技术的美就在于,通过使用很多简单的属性,你能创建出就连皮克斯动画制作公司也会赞叹的漂亮的消隐效果。其中代表性的一种就是CSS图片翻转效果,能让你看到一张卡片的正反两面上的内容。本文就是要用最简单的方法向大家介绍如何创建这种效果。

简单说明:这并不是第一篇我介绍这种技术的文章,但我发现那些都过于复杂了。网上还有很多其它的教材,但里面添加了很多多余的代码样式,需要读者去分清哪些是必要的,那些是无用的;本文避免了这些问题,只列出了必要的CSS代码,你可以在其上添加自己喜欢的风格来美化这些卡片。

(鼠标移到图片上看翻转效果)

[size=2em]WebHek
歪脖骇客


[size=2em]@歪脖骇客

Mozilla Web Developer, MooTools & jQuery Consultant, MooTools Core Developer, Javascript Fanatic, CSS Tinkerer, PHP Hacker, and web lover.




HTML代码

实现正反面效果的HTML代码,估计你也能想到应该是这样的:

<div class="flip-container" ontouchstart="this.classList.toggle('hover');">        <div class="flipper">                <div class="front">                        <!-- 前面内容 -->                </div>                <div class="back">                        <!-- 背面内容 -->                </div>        </div></div>

正如你想到的,应该有两个容器,分别存放卡片“前面”和“背面”,通过CSS,我们会指定这两个容器元素自己的作用。还有需要注意的是ontouchstart这段js,它能让你使用触屏来触发翻转动作。显然,你应该把这段代码单独提取出来,让JavaScript代码放到一起。

CSS代码

我敢打赌,你会感到惊讶,只需要如此少的代码(如果不考虑各浏览器CSS方言前缀):

/* entire container, keeps perspective */.flip-container {        perspective: 1000;}        /* flip the pane when hovered */        .flip-container:hover .flipper, .flip-container.hover .flipper {                transform: rotateY(180deg);        }.flip-container, .front, .back {        width: 320px;        height: 480px;}/* flip speed goes here */.flipper {        transition: 0.6s;        transform-style: preserve-3d;        position: relative;}/* hide back of pane during swap */.front, .back {        backface-visibility: hidden;        position: absolute;        top: 0;        left: 0;}/* front pane, placed above back */.front {        z-index: 2;}/* back, initially hidden pane */.back {        transform: rotateY(180deg);}

下面是大概的整个过程的原理:

  • 在最外层的容器元素上设置整个动画区域的透视(perspective)属性。
  • 当外层容器元素遇到鼠标悬停事件时,内部存放卡片的容器旋转180度。这里也是控制旋转速度的地方。如果将旋转值设置为-180deg,是反向旋转。
  • 表示卡片正面和背面的元素都要绝对定位,这样它们才能在相同的位置相互遮挡。它们的背面可视性(backface-visibility)属性设置为隐藏,这样每个卡片的背面在翻转时都是看不见的。
  • 将卡片的正面设置为一个比背面要高的z-index值,这样保证卡片的正面在最上面。
  • 将背面卡片旋转180度,这样让它扮演背面的角色。

这就是全部这些代码的作用!你把这段代码放到你的网页里,然后修饰一下卡片的样式就行了!

来自CSS动画专家Ana Tudor的提示

对卡片元素的某些属性设置一些特定的值(例如)(like overflow: hidden)会导致其子元素丧失3D变换功能。我认可他的观点,因为正是在本文的例子中我正好遇到了overflow: hidden相关的麻烦,它导致了3D变换子元素全都出现在了同一个平面上,有几个是被旋转了180度。

触发CSS翻转

(鼠标移到图片上看翻转效果)

[size=2em]WebHek
歪脖骇客


[size=2em]@歪脖骇客

Mozilla Web Developer, MooTools & jQuery Consultant, MooTools Core Developer, Javascript Fanatic, CSS Tinkerer, PHP Hacker, and web lover.




触发翻转
如果你喜欢用JavaScript来触发翻转动作,下面这个简单的css样式类就能帮你做到这样:

.flip-container:hover .flipper, .flip-container.hover .flipper, .flip-container.flip .flipper {        transform: rotateY(180deg);}

使用javascript给容器元素添加这个cssflip类就能触发卡片翻转——不需要用户悬停鼠标在上面。用document.querySelector("#myCard").classList.toggle("flip")实现它!

CSS竖向翻转

(鼠标移到图片上看翻转效果)

[size=2em]WebHek
歪脖骇客


[size=2em]@歪脖骇客

Mozilla Web Developer, MooTools & jQuery Consultant, MooTools Core Developer, Javascript Fanatic, CSS Tinkerer, PHP Hacker, and web lover.




执行竖向翻转也很简单,跟横向翻转一样,只需要修改一下transform-origin的值,然后让它按X轴旋转。

.vertical.flip-container {        position: relative;}        .vertical .back {                transform: rotateX(180deg);        }        .vertical.flip-container .flipper {                transform-origin: 100% 213.5px; /* 高的一半 */        }        .vertical.flip-container:hover .flipper {                transform: rotateX(-180deg);        }

注意这里用的是rotateX,而不是之前的rotateY。

让IE支持这种动画技术

需要针对IE对这段标准的卡片翻转代码进行特殊的修改,因为IE还没有实现现代浏览器中的transform功能。基本的做法就是对正面和背面两个卡片同时分别翻转:

/* entire container, keeps perspective */.flip-container {        perspective: 1000;        transform-style: preserve-3d;}        /*  UPDATED! flip the pane when hovered */        .flip-container:hover .back {                transform: rotateY(0deg);        }        .flip-container:hover .front {            transform: rotateY(180deg);        }.flip-container, .front, .back {        width: 320px;        height: 480px;}/* flip speed goes here */.flipper {        transition: 0.6s;        transform-style: preserve-3d;        position: relative;}/* hide back of pane during swap */.front, .back {        backface-visibility: hidden;        transition: 0.6s;        transform-style: preserve-3d;        position: absolute;        top: 0;        left: 0;}/*  UPDATED! front pane, placed above back */.front {        z-index: 2;        transform: rotateY(0deg);}/* back, initially hidden pane */.back {        transform: rotateY(-180deg);}/*         Some vertical flip updates */.vertical.flip-container {        position: relative;}        .vertical .back {                transform: rotateX(180deg);        }        .vertical.flip-container:hover .back {            transform: rotateX(0deg);        }        .vertical.flip-container:hover .front {            transform: rotateX(180deg);        }

使用上面的这段代码,IE10里也能正确的进行卡片翻转了!

基本效果



这个CSS卡片翻转动画技术一直是一个经典的案例,代表着CSS动画能够实现的效果,甚至3DCSS动画能实现的强大效果。优点就是使用的代码很少很简单。对于制作HTML5动画来说这种效果非常的实用,可以说完美。你还能想到其它用到这个效果的地方吗?




免费评分

参与人数 1热心值 +1 收起 理由
284912933 + 1 热心回复!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

hu007 发表于 2014-12-1 08:19
谢谢分享,收藏一下
龙龙的幸福 发表于 2014-12-1 08:41
现在很多人用的还是IE8  或者IE8核心的其他浏览器
wang48961016 发表于 2014-12-1 08:49
a5680497 发表于 2014-12-1 09:17
表示看不懂!!!!!!!!
284912933 发表于 2014-12-1 12:38
呃,代码看着有点乱。。。
manbajie 发表于 2014-12-2 11:13
来学习一下下
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-15 10:54

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表