纯css实现旋转的金字塔

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了纯css实现旋转的金字塔相关的知识,希望对你有一定的参考价值。

参考技术A

css是个神奇的东西,在学习的过程中你会发现绘画和艺术的美,金字塔是世界八大奇迹之一,设计精巧,计算精密,令世人赞叹。那么如何用CSS画一个金字塔呢?

人丑话不多,先看一下效果

金字塔是由5个面组成的,即4个侧面和1个底面。我们可以把它看作是一个童年时期玩过的元宝,或者端午节戴在身上的福字。为什么这么说呢?

“横看成岭侧成峰”,我们看金字塔的俯视图是不是会看到这样一个图形,如下图所示

这是一个平面图形,如果让这个平面图形具有立体的效果不就是一个金字塔了么。即将上图的(0,0)沿着x轴旋转一定角度即可实现。

接下来就是绘制“元宝”的形状,侧面是4个三角形,底面是一个正方形。实现三角形可以采用 clip-path 的属性对可视区域进行裁剪。

由上图可知: clip-path 的只能兼容 高版本浏览器 。polygon代表多边形,所以利用该属性可以绘制多如下图形:

有了上述的图形之后,我们需要进行特殊的处理,才能得到我们想要的形状。因为我们要搭建金字塔,所有我们塔边的高度或者宽度需要大于底部的宽度和长度,不然的话无法搭成塔尖而形成如下图形:

故需设置大于底部宽和高,我们这里选取为高度为200px,宽度为100px,宽度需要和底部宽度保持一致。

假设我们现在已经有一个金字塔,我们可以取它的一个横截面如下图:

通过sin函数

解上面反三角函数求得A大约为75deg,以此类推我们可以算出其他图形旋转角度。

将上述的两种三角形通过适当的平移和旋转,得到如下图形:

合并之后得到如下图形

通过使用css3中的3D转化属性,将上图进行转化即可:

由上图可知:transform-style:preserve-3d兼容是支持高版本浏览器,支持部分ie浏览器

以上就是本文的全部内容,全部都是由css实现包括:

纯CSS实现蜂窝六边形的个性相册

概述

纯CSS实现蜂窝六边形的个性相册

详细

此案例主要用到CSS3的 transform 和 transition属性,还有nth-child() 选择器

一、准备工作

1、主要运用到CSS3的3D transform变换

 

  • transform:向元素应用 2D 或 3D 转换。该属性允许我们对元素进行旋转、缩放、移动或倾斜

描述测试
none 定义不进行转换。 测试
matrix(n,n,n,n,n,n) 定义 2D 转换,使用六个值的矩阵。 测试
matrix3d(n,n,n,n,n,n,n,n,n,n,n,n,n,n,n,n) 定义 3D 转换,使用 16 个值的 4x4 矩阵。  
translate(x,y) 定义 2D 转换。 测试
translate3d(x,y,z) 定义 3D 转换。  
translateX(x) 定义转换,只是用 X 轴的值。 测试
translateY(y) 定义转换,只是用 Y 轴的值。 测试
translateZ(z) 定义 3D 转换,只是用 Z 轴的值。  
scale(x,y) 定义 2D 缩放转换。 测试
scale3d(x,y,z) 定义 3D 缩放转换。  
scaleX(x) 通过设置 X 轴的值来定义缩放转换。 测试
scaleY(y) 通过设置 Y 轴的值来定义缩放转换。 测试
scaleZ(z) 通过设置 Z 轴的值来定义 3D 缩放转换。  
rotate(angle) 定义 2D 旋转,在参数中规定角度。 测试
rotate3d(x,y,z,angle) 定义 3D 旋转。  
rotateX(angle) 定义沿着 X 轴的 3D 旋转。 测试
rotateY(angle) 定义沿着 Y 轴的 3D 旋转。 测试
rotateZ(angle) 定义沿着 Z 轴的 3D 旋转。 测试
skew(x-angle,y-angle) 定义沿着 X 和 Y 轴的 2D 倾斜转换。 测试
skewX(angle) 定义沿着 X 轴的 2D 倾斜转换。 测试
skewY(angle) 定义沿着 Y 轴的 2D 倾斜转换。 测试
perspective(n) 为 3D 转换元素定义透视视图。 测试


2、transition 属性

transition 属性是一个简写属性,用于设置四个过渡属性:

  • transition-property

  • transition-duration

  • transition-timing-function

  • transition-delay

注释:请始终设置 transition-duration 属性,否则时长为 0,就不会产生过渡效果。

 

描述
transition-property 规定设置过渡效果的 CSS 属性的名称。
transition-duration 规定完成过渡效果需要多少秒或毫秒。
transition-timing-function 规定速度效果的速度曲线。
transition-delay 定义过渡效果何时开始。

 

3、nth-child() 选择器

 

定义和用法

:nth-child(n) 选择器匹配属于其父元素的第 N 个子元素,不论元素的类型。

n 可以是数字、关键词或公式。

提示:请参阅 :nth-of-type() 选择器,该选择器选取父元素的第 N 个指定类型的子元素。

二、程序实现

 

实现过程:

1、编写HTML。

<li class="hex"> <a class="hexIn" href="#"> <img src="img/1.png"  />
    <h1>This is a title</h1>
    <p>Some sample text about the article this hexagon leads to</p>
    </a> </li>
  <li class="hex"> <a class="hexIn" href="#"> <img src="img/2.png"  />
    <h1>This is a title</h1>
    <p>Some sample text about the article this hexagon leads to</p>
    </a> </li>

2、编写六角形边框和动画效果的样式类。

.hex * {
    position: absolute;
    visibility: visible;
    outline:1px solid transparent; /* fix for jagged edges in FF on hover transition */
}
.hexIn:hover h1, .hexIn:focus h1,
.hexIn:hover p, .hexIn:focus p{
    -webkit-transform:translateY(0%) translatez(-1px);
        -ms-transform:translateY(0%) translatez(-1px);
            transform:translateY(0%) translatez(-1px);
}

三、文件、运行截图

1、文件截图:

技术分享图片

通过对每一个LI渲染成六角形,并实现自动嵌合式排列的效果,最终构成“蜂窝”;同时每个LI中含有A标签,可通过CSS3实现鼠标滑过时显示标题和说明文字的动画特效。

 

2、运行效果图:

打开index.html,可看到最终效果。(兼容IE9+,chrome,firefox,safari等主流浏览器)

技术分享图片

注:本文著作权归作者,由demo大师发表,拒绝转载,转载需要作者授权




以上是关于纯css实现旋转的金字塔的主要内容,如果未能解决你的问题,请参考以下文章

SceneKit - 旋转和动画SCNNode

OpenGL 立方体和金字塔

计算机图形学-图形几何变换

同时旋转多个立方体的问题

围绕Y轴旋转而不改变位置

如何在全局轴上旋转图形,而不是局部轴?