CSS3 Tranform 3D 的应用

CSS3 Tranform 3D 的应用

一、perspective 属性

1. 作用:

设置元素被查看位置的视图,类似于眼睛到屏幕的距离,一般跟 perspective-origin 共同作用在一个父元素上

  • 属性值 = 屏幕分辩率 * 屏幕和我们眼睛的距离

  • 当为元素定义 perspective 属性时,其子元素会获得透视效果,而不是元素本身

  • perspective 属性只影响 3D 转换元素

2. 作用范围

  • 舞台效果: 作用在 transform 属性元素的父元素上,里面的元素都会受到改属性的影响,而且显示的效果跟子元素在父元素的位置有关系。

    perspective: 200px

  • 单个元素:和 transform 属性 共同作用在同一元素中:

    transform: perspective(500px) rotateY(45deg);

二、transform 属性

1. 属性:

  • translateZ: 元素向着它朝的方向(也就是其经过rotate之后) “走出去” 的距离
  • rotateX( xx deg)
  • rotateY( xx deg)
  • rotateZ( xx deg)
  • ...

三、perspective-origin 属性

1. 作用

设置 3D 元素的基点位置(也就是我们眼睛看的位置),默认就是所看舞台或元素的中心

perspective-origin: 25% 75%;

四、transform-style

1. 作用

利用该属性可以使被转换的子元素(不是后代)保留其 3D 转换:

transform-style: preserve-3d / flat

五、backface-visibility

1. 作用

该属性定义当元素不面向屏幕时(前面有3d元素挡住时)是否可见,可以想象各个面连成一个实体的形状,后面的面会被前面的面挡住看不见。

backface-visibility : hidden / visible;
  • 为每个面设置 backface-visibility: visible,默认值就是 visible
  • 为每个面设置 backface-visibility: hidden

六、例子

<body>
    <div class="center showbf">
        <div class="cube">
        <div class="face front">1</div>
        <div class="face back">2</div>
        <div class="face right">3</div>
        <div class="face left">4</div>
        <div class="face top">5</div>
        <div class="face bottom">6</div>
        </div>
    <div>
</body>
.hidebf div {
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}
.showbf div {
    backface-visibility: visible;
    -webkit-backface-visibility: visible;
}

.center{
    margin: auto;
    margin-top: 100px;
    width: 80%;
    height: 300px;
    border: 1px solid; 
    perspective: 200px;          /* prespective 和 perspective-origin 一般一起在外层元素上使用 */
    perspective-origin: 50% 5%;  /* **** */
}

.cube {
    width: 100px;
    height: 100px;
    margin: auto;
    margin-top: 100px;
    transform-style: preserve-3d;   /* 让多个子元素之间的 3D 关系像我们想象一样呈现 */
    transition: 1s ease;
    transform: rotateY(0deg);  /* 改变角度看 */
}
.face {
    display: block;
    position: absolute;
    width: 100px;
    height: 100px;
    border: none;
    line-height: 100px;
    font-family: sans-serif;
    font-size: 60px;
    color: white;
    text-align: center;
}

/* Define each face based on direction */
.front {
    background: rgba(0, 0, 0, 0.3);
    transform: translateZ(80px);
}
.back {
    background: rgba(0, 255, 0, 1);
    color: black;
    transform: rotateY(180deg) translateZ(80px);
}
.right {
    background: rgba(196, 0, 0, 0.7);
    transform: rotateY(90deg) translateZ(80px);
}
.left {
    background: rgba(0, 0, 196, 0.7);
    transform: rotateY(-90deg) translateZ(80px);
}
.top {
    background: rgba(196, 196, 0, 0.7);
    transform: rotateX(90deg) translateZ(80px);
}
.bottom {
    background: rgba(196, 0, 196, 0.7);
    transform: rotateX(-90deg) translateZ(80px);
}

上面如果把 div class="cube" 的元素旋转 rotateY(30deg) 其效果如下:

但是如果把 prespective 从 cube 的父元素移到 cube 上,其旋转效果如下:

参考:

好吧,CSS3 3D transform变换,不过如此!


注意

转载、引用,但请标明作者和原文地址

posted @ 2018-03-05 21:25  另一个小菜头  阅读(324)  评论(0编辑  收藏  举报