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>