CSS3_3D变换(七)

1、CSS3_3D变换

1.1 3D空间与景深

3D空间:在父元素中将属性transform-style设置为preserve-3d开启3D空间,默认值为flat(开启2D空间);

景深:人眼与平面的距离,产生透视效果,使得效果更加立体。

html 复制代码
<!DOCTYPE html>
<html lang="zh-CN">

<head>
    <meta charset="UTF-8">
    <title>3D变换与景深</title>
    <style>
        .outer {
            height: 200px;
            width: 200px;
            border: 1px solid black;
            margin: 0 auto;
            margin-top: 100px;

            /* 开启3D空间 */
            transform-style: preserve-3d;
            /* 设置景深 */
            perspective: 500px;
        }

        .inner {
            height: 200px;
            width: 200px;
            background-color: aquamarine;
            text-align: center;

            transform: rotateX(30deg);
        }
    </style>
</head>

<body>
    <div class="outer">
        <div class="inner">
            示例文字
        </div>
    </div>
</body>

</html>
1.2 透视点的位置

透视点:人眼观察的位置,在父元素中设置。

html 复制代码
<!DOCTYPE html>
<html lang="zh-CN">

<head>
    <meta charset="UTF-8">
    <title>透视点的位置</title>
    <style>
        .outer {
            height: 200px;
            width: 200px;
            border: 1px solid black;
            margin: 0 auto;
            margin-top: 100px;

            /* 开启3D空间 */
            transform-style: preserve-3d;
            /* 设置景深 */
            perspective: 500px;
            /* 设置观察点的位置(在右下角观察) */
            perspective-origin: 500px 500px;
        }

        .inner {
            height: 200px;
            width: 200px;
            background-color: aquamarine;
            text-align: center;

            transform: rotateX(30deg);
        }
    </style>
</head>

<body>
    <div class="outer">
        <div class="inner">
            示例文字
        </div>
    </div>
</body>

</html>
1.3 3D位移
html 复制代码
<!DOCTYPE html>
<html lang="zh-CN">

<head>
    <meta charset="UTF-8">
    <title>位移</title>
    <style>
        .outer {
            height: 200px;
            width: 200px;
            border: 1px solid black;
            margin: 0 auto;
            margin-top: 100px;

            /* 开启3D空间 */
            transform-style: preserve-3d;
            /* 设置景深 */
            perspective: 500px;
            /* 设置观察点的位置(在右下角观察) */
            /* perspective-origin: 500px 200px; */
        }

        .inner {
            height: 200px;
            width: 200px;
            background-color: aquamarine;
            text-align: center;

            /* 设置Z轴距离,不能写百分比 */
            /* transform: translateZ(150px); */
            /* 设置在X、Y、Z轴的位移距离,可以写百分比 */
            transform: translate3d(12px, 50%, 3px);
        }
    </style>
</head>

<body>
    <div class="outer">
        <div class="inner">
            示例文字
        </div>
    </div>
</body>

</html>
1.4 3D旋转
html 复制代码
<!DOCTYPE html>
<html lang="zh-CN">

<head>
    <meta charset="UTF-8">
    <title>旋转</title>
    <style>
        .outer {
            height: 200px;
            width: 200px;
            border: 1px solid black;
            margin: 0 auto;
            margin-top: 100px;

            /* 开启3D空间 */
            transform-style: preserve-3d;
            /* 设置景深 */
            perspective: 500px;
        }

        .inner {
            height: 200px;
            width: 200px;
            background-color: aquamarine;
            text-align: center;
            /* 设置X轴旋转角度 */
            /* transform: rotateX(100deg); */
            /* 设置Y轴旋转角度 */
            /* transform: rotateY(100deg); */
            /* 设置X、Y、Z轴旋转角度倍数 */
            transform: rotate3d(1, 1, 1, 30deg);
        }
    </style>
</head>

<body>
    <div class="outer">
        <div class="inner">
            示例文字
        </div>
    </div>
</body>

</html>
1.5 3D缩放
html 复制代码
<!DOCTYPE html>
<html lang="zh-CN">

<head>
    <meta charset="UTF-8">
    <title>缩放</title>
    <style>
        .outer {
            height: 200px;
            width: 200px;
            border: 1px solid black;
            margin: 0 auto;
            margin-top: 100px;
            /* 开启3D空间 */
            transform-style: preserve-3d;
            /* 设置景深 */
            perspective: 500px;
        }

        .inner {
            height: 200px;
            width: 200px;
            background-color: aquamarine;
            text-align: center;


            /* 设置Z轴缩放比例,由于html元素没有厚度,则该属性调整景深,景深除以缩放的比例 */
            transform: scaleZ(4) rotateY(30deg);
            /* 设置3D缩放比例,X、Y、Z轴的缩放比例 */
            /* transform: scale3d(2,1,1) rotateY(30deg); */
        }
    </style>
</head>

<body>
    <div class="outer">
        <div class="inner">
            示例文字
        </div>
    </div>
</body>

</html>
1.6 3D多重变换
html 复制代码
<!DOCTYPE html>
<html lang="zh-CN">

<head>
    <meta charset="UTF-8">
    <title>多重变换</title>
    <style>
        .outer {
            height: 200px;
            width: 200px;
            border: 1px solid black;
            margin: 0 auto;
            margin-top: 100px;
            /* 开启3D空间 */
            transform-style: preserve-3d;
            /* 设置景深 */
            perspective: 500px;
        }

        .inner {
            height: 200px;
            width: 200px;
            background-color: aquamarine;
            text-align: center;
            line-height: 200px;

            transform-origin: top 20px;
            transform: rotateX(60deg);
        }
    </style>
</head>

<body>
    <div class="outer">
        <div class="inner">
            示例文字
        </div>
    </div>
</body>

</html>
1.7 3D背部
html 复制代码
<!DOCTYPE html>
<html lang="zh-CN">

<head>
    <meta charset="UTF-8">
    <title>背部</title>
    <style>
        .outer {
            height: 200px;
            width: 200px;
            border: 1px solid black;
            margin: 0 auto;
            margin-top: 100px;
            /* 开启3D空间 */
            transform-style: preserve-3d;
            /* 设置景深 */
            perspective: 500px;
        }

        .inner {
            height: 200px;
            width: 200px;
            background-color: aquamarine;
            text-align: center;
            line-height: 200px;

            transform: rotateY(180deg);
            /* 设置背部不可见 */
            backface-visibility: hidden;
        }
    </style>
</head>

<body>
    <div class="outer">
        <div class="inner">
            示例文字
        </div>
    </div>
</body>

</html>
相关推荐
释怀不想释怀12 小时前
Ajax,vue生命周期(自动加载页面发出请求)Axios
前端·javascript·ajax
一点晖光12 小时前
ios底部按钮被挡住
前端·ios·微信小程序
Light6018 小时前
CSS逻辑革命:原生if()函数如何重塑我们的样式编写思维
前端·css·响应式设计·组件化开发·css if函数·声明式ui·现代css
蜡笔小嘟19 小时前
宝塔安装dify,更新最新版本--代码版
前端·ai编程·dify
ModyQyW20 小时前
HBuilderX 4.87 无法正常读取 macOS 环境配置的解决方案
前端·uni-app
bitbitDown20 小时前
我的2025年终总结
前端
五颜六色的黑20 小时前
vue3+elementPlus实现循环列表内容超出时展开收起功能
前端·javascript·vue.js
wscats21 小时前
Markdown 编辑器技术调研
前端·人工智能·markdown
EnoYao21 小时前
Markdown 编辑器技术调研
前端·javascript·人工智能
JIngJaneIL21 小时前
基于java+ vue医院管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot