`

HTML5 CSS3 专题 :诱人的实例 3D展示商品信息

 
阅读更多

http://blog.csdn.net/lmj623565791/article/details/32974051

强化下perspective和transform:translateZ的用法。传统的商品展示或许并不能很好的吸引用户的注意力,但是如果在展示中添加适当的3D元素,~说不定效果不错哈~

效果图:

说明一下:这个创意不是我想的,哈~模仿别人的,创意应该是w3cplus上的。当然了,重点是教大家如何做,就当高仿了~

 

首先,先教大家利用CSS3制作一个正方体:

在木有CSS前,这样的立方体,应该很难制作吧~嗯,我觉得很难~

html:

 

[html] view plaincopy在CODE上查看代码片派生到我的代码片
  1. <body>  
  2.   
  3.   
  4. <div class="wapper">  
  5.     <div class="cube">  
  6.         <div class="side  front">1</div>  
  7.         <div class="side   back">6</div>  
  8.         <div class="side  right">4</div>  
  9.         <div class="side   left">3</div>  
  10.         <div class="side    top">5</div>  
  11.         <div class="side bottom">2</div>  
  12.     </div>  
  13. </div>  
  14.   
  15. </body>  


wapper为此效果的舞台,即设置perspective的元素,如果多个元素共享一个舞台,那么从一个视线观察所以的元素的效果是不一样的,就相当我们正常情况下,站在一排倾斜成45度的门前面,每个门对于我们视线来说,角度是不同的;div#cube代表一个立方体,然后6个DIV分别代表每个面。

 

div#cube设置transform-style:preserve-3d,然后每个元素设置rotate和translateZ

现在所有的面重叠在同一个平面上,我们分别让:

font往前即Z轴方向移动半个边长(translateZ(50px))的距离即50px;

back先绕Y轴旋转180度,这样让字体是对外的,然后translateZ(50px),因为此时已经旋转了180度,所以tanslateZ是向下的,

同理,其他面分别绕X轴或者Y轴旋转90度,然后translateZ(50px)

 

CSS:

 

[html] view plaincopy在CODE上查看代码片派生到我的代码片
  1. .wapper  
  2.        {  
  3.            margin: 100px auto 0;  
  4.            width: 100px;  
  5.            height: 100px;  
  6.            -webkit-perspective: 1200px;  
  7.            font-size: 50px;  
  8.            font-weight: bold;  
  9.            color: #fff;  
  10.        }  
  11.   
  12.        .cube  
  13.        {  
  14.   
  15.            position: relative;  
  16.            width: 100px;  
  17.            -webkit-transform: rotateX(-40deg) rotateY(32deg);  
  18.            -webkit-transform-style: preserve-3d;  
  19.        }  
  20.   
  21.        .side  
  22.        {  
  23.            text-align: center;  
  24.            line-height: 100px;  
  25.            width: 100px;  
  26.            height: 100px;  
  27.            background: rgba(255, 99, 71, 0.6);  
  28.            border: 1px solid rgba(0, 0, 0, 0.5);  
  29.            position: absolute;  
  30.        }  
  31.   
  32.        .front  
  33.        {  
  34.            -webkit-transform: translateZ(50px);  
  35.        }  
  36.   
  37.        .top  
  38.        {  
  39.            -webkit-transform: rotateX(90deg) translateZ(50px);  
  40.        }  
  41.   
  42.        .right  
  43.        {  
  44.            -webkit-transform: rotateY(90deg) translateZ(50px);  
  45.        }  
  46.   
  47.        .left  
  48.        {  
  49.            -webkit-transform: rotateY(-90deg) translateZ(50px);  
  50.        }  
  51.   
  52.        .bottom  
  53.        {  
  54.            -webkit-transform: rotateX(-90deg) translateZ(50px);  
  55.        }  
  56.   
  57.        .back  
  58.        {  
  59.            -webkit-transform: rotateY(-180deg) translateZ(50px);  
  60.        }  


对于显示效果,可以调节perspective的距离~

 

好了,立方体理解了,那么这个商品展示就没什么难度了;两个DIV分别代表两个面,一个是图片,一个是介绍,初始时,介绍绕X轴先旋转90deg,然后当鼠标移动时,将整个盒子绕x轴旋转90deg即可。

HTML:

 

[html] view plaincopy在CODE上查看代码片派生到我的代码片
  1. <!DOCTYPE html>  
  2. <html>  
  3. <head>  
  4.     <title></title>  
  5.     <meta charset="utf-8">  
  6.     <link href="css/reset.css" rel="stylesheet" type="text/css">  
  7.   
  8.       
  9. </head>  
  10. <body>  
  11.   
  12.   
  13. <ul id="content">  
  14.   
  15.     <li>  
  16.         <div class="wrapper">  
  17.             <img src="images/a.png">  
  18.             <span class="information">  
  19.               <strong>Contact Form</strong> The easiest way to add a contact form to your shop.  
  20.             </span>  
  21.         </div>  
  22.     </li>  
  23.   
  24.     <li>  
  25.         <div class="wrapper">  
  26.             <img src="images/b.jpeg">  
  27.             <span class="information">  
  28.               <strong>Contact Form</strong> The easiest way to add a contact form to your shop.  
  29.             </span>  
  30.         </div>  
  31.   
  32.     </li>  
  33.   
  34.     <li>  
  35.         <div class="wrapper">  
  36.             <img src="images/c.png">  
  37.             <span class="information">  
  38.               <strong>Contact Form</strong> The easiest way to add a contact form to your shop.  
  39.             </span>  
  40.         </div>  
  41.   
  42.     </li>  
  43.   
  44. </ul>  
  45.   
  46.   
  47. </body>  
  48. </html>  


CSS:

 

 

  1. <style type="text/css">  
  2.         body  
  3.         {  
  4.             font-family: Tahoma, Arial;  
  5.         }  
  6.   
  7.         #content  
  8.         {  
  9.             margin: 100px auto 0;  
  10.         }  
  11.   
  12.         #content li, #content .wrapper, #content li img, #content li span  
  13.         {  
  14.             width: 310px;  
  15.             height: 100px;  
  16.         }  
  17.   
  18.         #content li  
  19.         {  
  20.             cursor: pointer;  
  21.             -webkit-perspective: 4000px;  
  22.             width: 310px;  
  23.             height: 100px;  
  24.             float: left;  
  25.             margin-left: 60px;  
  26.             /*box-shadow: 2px 2px 5px #888888;*/  
  27.   
  28.         }  
  29.   
  30.         #content .wrapper  
  31.         {  
  32.             position: relative;  
  33.             -webkit-transform-style: preserve-3d;  
  34.             -webkit-transition: -webkit-transform .6s;  
  35.         }  
  36.   
  37.         #content li img  
  38.         {  
  39.             top: 0;  
  40.             border-radius: 3px;  
  41.             box-shadow: 0px 3px 8px rgba(0, 0, 0, 0.3);  
  42.             position: absolute;  
  43.             -webkit-transform: translateZ(50px);  
  44.             -webkit-transition: all .6s;  
  45.         }  
  46.   
  47.         #content  li span  
  48.         {  
  49.             background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, rgba(236, 241, 244, 1)), color-stop(100%, rgba(190, 202, 217, 1)));  
  50.             text-shadow: 1px 1px 1px rgba(255, 255, 255, 0.5);  
  51.             position: absolute;  
  52.             -webkit-transform: rotateX(-90deg) translateZ(50px);  
  53.             -webkit-transition: all .6s;  
  54.             display: block;  
  55.             top: 0;  
  56.             text-align: left;  
  57.             border-radius: 15px;  
  58.             font-size: 12px;  
  59.             padding: 10px;  
  60.             width: 290px;  
  61.             height: 80px;  
  62.             text-shadow: 1px 1px 1px rgba(255, 255, 255, 0.5);  
  63.             box-shadow: none;  
  64.         }  
  65.   
  66.         #content li span strong  
  67.         {  
  68.             display: block;  
  69.             margin: .2em 0 .5em 0;  
  70.             font-size: 20px;  
  71.             font-family: "Oleo Script";  
  72.         }  
  73.   
  74.         #content li:hover .wrapper  
  75.         {  
  76.             -webkit-transform: rotateX(95deg);  
  77.         }  
  78.   
  79.         #content li:hover img  
  80.         {  
  81.             box-shadow: none;  
  82.             border-radius: 15px;  
  83.         }  
  84.   
  85.         #content li:hover span  
  86.         {  
  87.             box-shadow: 0px 3px 8px rgba(0, 0, 0, 0.3);  
  88.             border-radius: 3px;  
  89.         }  
  90.   
  91.   
  92.     </style>  


CSS基本在上面已经分析过了,这里说明一点,我们给没件商品弄了一个div.wapper看似是多余,其实不是,因为我们希望每个商品都是正常的90deg翻转,所以我们不能让所有的商品共享一个舞台,于是我们添加了一个div.wapper让他设置transform-style:preverse-3d,然后每个li分别设置舞台效果perspective。最终翻转效果实在div.wapper上。

 

 

好了,相信这几个例子,大家已经可以很好的使用perspective和translateZ创造一些很炫的立体效果,欢迎各位指点~

分享到:
评论

相关推荐

    HTML5 CSS3 专题 :3D展示商品信息项目完整实例源码

    在"HTML5 CSS3 专题:3D展示商品信息项目完整实例源码"这个项目中,我们将深入探讨如何利用这两者来创建一个引人入胜的商品3D展示效果。 首先,HTML5引入了许多新的元素,如`&lt;article&gt;`、`&lt;section&gt;`、`&lt;nav&gt;`等,...

    HTML5 CSS3 专题 :诱人的实例 3D旋转木马效果相册实例源码

    在本实例中,我们将深入探讨一个基于HTML5和CSS3的3D旋转木马效果相册,这是一个充满吸引力的图片展示方式,能够为用户带来独特的浏览体验。 3D旋转木马效果相册利用了CSS3的transform属性,尤其是rotateY()和...

    HTML5+CSS3实例 :3D立方体旋转

    本实例的3D立方体旋转动画,不仅展示了HTML5和CSS3的强大力量,也提供了丰富的学习资源,帮助开发者掌握现代网页设计的前沿技术。通过深入研究和实践这个例子,可以提升对3D效果的理解,为创建更具吸引力和交互性的...

    HTML5 CSS3 : 3D立方体旋转动画实例源码

    总的来说,这个3D立方体旋转动画实例展示了HTML5和CSS3的强大能力,不仅可以创建引人入胜的视觉效果,还能提高用户交互体验。通过学习和实践此类项目,开发者可以提升自己在Web前端开发领域的技能,尤其是在网页动态...

    HTML5 + CSS3 实现 3d 室内布局源码

    这个“HTML5 + CSS3 实现 3d 室内布局源码”项目是一个很好的实例,展示了如何利用这两种技术来构建具有三维效果的室内设计展示。 首先,HTML5是超文本标记语言的最新版本,它引入了许多新的元素和功能,旨在提高...

    HTML5CSS3 3D环形图片墙 伴随旋转动画

    此外,HTML5的`data-*`自定义属性可以用来存储与图片相关的信息,如旋转角度、缩放比例等,这些信息将在CSS3的动画中用到。 接着,CSS3的3D转换功能在这里发挥了关键作用。CSS3的`transform`属性允许对元素进行平移...

    Html5+Css3-手机App实例

    在这个“Html5+Css3-手机App实例”中,我们将深入探讨如何利用这两项技术构建适用于移动设备的App。 HTML5是超文本标记语言的第五个版本,相比之前的HTML4,它引入了许多新的元素、属性和API,旨在提升网页的互动性...

    HTML5+CSS3实例源码(包含20个)

    实例代码通常会展示如何有效地组合HTML5元素和CSS3属性,例如如何使用CSS3的变形(transform)、过渡(transition)和动画(animation)来创建动态效果,或者如何利用Flexbox或Grid布局创建复杂且灵活的网页结构。...

    css3d演示html

    【CSS3D演示HTML】是关于使用CSS3的3D转换技术来创建具有立体效果的网页元素的示例。在现代网页设计中,CSS3D(CSS 3D)是一种强大的工具,它允许开发者通过纯CSS实现动态的、立体的视觉效果,无需依赖JavaScript...

    html5+css3制造3D电影海报旋转轮播展示

    html5+css3制造3D电影海报旋转轮播展示 html5+css3制造3D电影海报旋转轮播展示

    HTML5 CSS3 :无插件拖拽上传图片实例源码

    这个实例对于学习和理解HTML5的拖放功能和File API非常有帮助,同时也展示了如何结合CSS3来提升用户体验。通过实践这个源码,开发者可以掌握无插件图片上传的核心技术,并将其应用到自己的项目中,为用户提供更友好...

    HTML5+CSS3:3D展示商品信息示例

    传统的商品展示或许并不能很好的吸引用户的注意力,但是如果在展示中添加适当的3D元素,~说不定效果不错哈~ 效果图: 说明一下:这个创意不是我想的,哈~模仿别人的,创意应该是w3cplus上的。当然了,重点是教大家...

    HTML5+CSS3实现的3D书本展示效果源码

    - 平铺展示:这种模式可能通过CSS3的3D变换让每本书的信息(如封面、作者名等)在平面上以立体的方式展开,用户可以通过鼠标交互来查看书籍的各个侧面。 - 书架展示:这个效果可能通过创建一个虚拟的3D空间,模拟...

    HTML5 CSS3 : 进度条的实现实例源码

    在本实例中,我们将深入探讨如何使用HTML5和CSS3来实现一个具有视觉吸引力的进度条。进度条在网页中广泛应用,如文件上传、加载过程、任务进度指示等,能有效地向用户反馈操作状态。 首先,HTML5引入了一个新的元素...

    CSS3打造百度贴吧的3D翻牌效果完整实例源码

    **CSS3打造百度贴吧的3D翻牌效果完整实例源码** 在现代网页设计中,为了提升用户体验,各种视觉特效被广泛应用。其中,3D翻牌效果是一种极具吸引力的交互方式,常见于卡片式设计、轮播图或者展示类页面。本实例将...

    HTML5+CSS3简单有趣的实例

    在这个“HTML5+CSS3简单有趣的实例”压缩包中,包含了一些适合初学者入门和教学使用的项目,如日历、轮播图和模态弹窗等。这些实例将帮助学习者更好地理解HTML5的新特性以及CSS3的强大样式控制能力。 HTML5是超文本...

    HTML5 CSS3 3D 足球队队员介绍.rar

    3D 足球队队员介绍,这个是采用CSS3技术实现的效果,HTML5 CSS3三维效果,使用本实例中的效果,使用了googleapis,还自定义了超多的JS类库,以足球场为核心,显示各队员头像,单击头像可显示该运动员信息,并以前峰...

    HTML5+CSS3实现3d室内布局源码

    在"HTML5+CSS3实现3d室内布局源码"这个项目中,我们可以深入探讨这两项技术如何应用于创建三维室内设计展示。 首先,HTML5作为新一代的超文本标记语言,引入了许多新特性,比如离线存储、拖放功能、媒体元素(audio...

    HTML5 CSS3 :canvas 模拟实现电子彩票刮刮乐实例代码

    在这个“HTML5 CSS3:canvas模拟实现电子彩票刮刮乐实例代码”中,我们将深入探讨如何利用Canvas API创建一个互动式的刮刮乐彩票效果。 首先,Canvas的基本用法是通过`&lt;canvas&gt;`标签在HTML文档中创建一个画布,然后...

    HTML5 CSS3 3D JQuery 实现照片墙

    HTML5、CSS3、3D效果以及JQuery的结合在现代网页设计中是常见的技术组合,它们能够创造出极具视觉吸引力的交互式用户体验。本项目利用这些技术实现了一个超酷的3D照片墙特效,适用于创建引人注目的照片库或展示区。 ...

Global site tag (gtag.js) - Google Analytics