15.变形:平移、旋转与缩放
2022/3/26 6:25:19
本文主要是介绍15.变形:平移、旋转与缩放,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
变形就是指通过 css 来改变元素的形状或位置
变形不会影响到页面的布局
transform
用来设置元素的变形效果
1、平移
translateX()
沿着由方向平移translateY()
沿着 y 轴方向平移translateZ()
沿着 z 轴方向平移平移元素
百分比是相对于自身计算的
几种水平垂直双方向居中的方式对比
-
绝对定位的方式
css
-
/* 这种居中方式,只适用于元素的大小确定 */ position: absolute; top: 0; left: 0; bottom: 0; right: 0; margin: auto;
-
CSStable-cell
的方式/* table-cell的方式具有一定局限性 */ display: table-cell; vertical-align: middle; text-align: center;
-
CSStransform
的方式/* transform变形平移的方式 */ position: absolute; left: 50%; top: 50%; transform: translateX(-50%) translateY(-50%);
浮出效果
CSSdiv { float: left; width: 200px; height: 300px; background-color: silver; margin: 100px 50px auto 50px; transition: all 0.3s; } div:hover { box-shadow: 0 0 10px rgba(0, 0, 0, 0.2); transform: translateY(-5px); }
2、Z 轴平移
z 轴平移,调整元素在 z 轴的位置,正常情况就是调整元素和人眼之间的距离,距离越大,元素离人越近
z 轴平移属于立体效果(近大远小),默认情况下网页是不支持透视,如果需要看见效果必须要设置网页的视距
透视效果
CSShtml { background-color: rgb(71, 44, 32); perspective: 800px; } .box { width: 200px; height: 300px; background-color: silver; margin: 100px auto; transition: all 0.3s; } .box:hover { box-shadow: 0 0 10px rgba(0, 0, 0, 0.2); transform: translateZ(200px); }
3、旋转
通过旋转可以使元素沿着 x、y 或 z 旋转指定的角度
rotateX()
rotateY()
rotateZ()
/* transform: rotateY(0.5turn); */ transform: rotateY(180deg);
4、缩放
对元素进行缩放的函数
scalex()
水平方向缩放scaleY()
垂直方向缩放scale()
双方向的缩放
.box { height: 200px; width: 200px; background-color: #bfa; margin: 200px auto; transition: 2s; } .box:hover { /* transform: scaleX(2); */ /* transform: scaleY(2); */ transform: scale(2); /* 变形的原点 */ transform-origin: 0 0; }
5、实战
鸭子表
html 代码
<div class="clock"> <div class="hour-wrapper"> <div class="hour"></div> </div> <div class="minute-wrapper"> <div class="minute"></div> </div> <div class="second-wrapper"> <div class="second"></div> </div> </div>
css 代码
复制代码- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
- 61
- 62
- 63
- 64
- 65
- 66
- 67
- 68
- 69
.clock { width: 500px; height: 500px; background-image: url("assets/鸭子表/clock.png"); background-image: url("assets/鸭子表/clock_duck.jpg"); background-size: cover; margin: 100px auto; position: relative; } .clock > div { position: absolute; top: 0; bottom: 0; left: 0; right: 0; margin: auto; } .clock > div > div { height: 50%; margin: 0 auto; } /* 时针 */ .hour-wrapper { height: 60%; width: 60%; animation: clock-run 720s infinite; } .hour { width: 8px; background-color: black; } /* 分针 */ .minute-wrapper { height: 75%; width: 75%; animation: clock-run 60s steps(60) infinite; } .minute { width: 4px; background-color: black; } /* 秒针 */ .second-wrapper { height: 90%; width: 90%; animation: clock-run 1s steps(60) infinite; } .second { width: 2px; background-color: red; } @keyframes clock-run { from { transform: rotateZ(0); } to { transform: rotateZ(360deg); } }
复仇者联盟
html 代码
复制代码- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
<div class="cube"> <div class="surface1"></div> <div class="surface2"></div> <div class="surface3"></div> <div class="surface4"></div> <div class="surface5"></div> <div class="surface6"></div> </div>
css 代码
复制代码- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
- 61
- 62
- 63
- 64
html { perspective: 800px; } .cube { height: 200px; width: 200px; margin: 200px auto; position: relative; /* 设置3d变形效果 */ transform-style: preserve-3d; animation: cube-rotate 12s infinite linear; } .cube div { height: 200px; width: 200px; background-size: cover; position: absolute; top: 0; left: 0; /* 为元素设置透明效果 */ opacity: 0.85; } .surface1 { background-image: url("/assets/复仇者联盟/1.jpg"); transform: translateX(-100px) rotateY(90deg); } .surface2 { background-image: url("/assets/复仇者联盟/2.jpg"); transform: translateX(100px) rotateY(90deg); } .surface3 { background-image: url("/assets/复仇者联盟/3.jpg"); transform: translateY(-100px) rotateX(90deg); } .surface4 { background-image: url("/assets/复仇者联盟/4.jpg"); transform: translateY(100px) rotateX(90deg); } .surface5 { background-image: url("/assets/复仇者联盟/5.jpg"); transform: translateZ(-100px); } .surface6 { background-image: url("/assets/复仇者联盟/6.jpg"); transform: translateZ(100px); } @keyframes cube-rotate { from { transform: rotateX(0) rotateY(0) rotateZ(0); } to { transform: rotateX(1turn) rotateY(2turn) rotateZ(3turn); } }
这篇关于15.变形:平移、旋转与缩放的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23Java云原生学习:从入门到实践
- 2024-11-22Java创业学习:初学者的全面指南
- 2024-11-22JAVA创业学习:零基础入门到实战应用教程
- 2024-11-22Java创业学习:从零开始的Java编程入门教程
- 2024-11-22Java对接阿里云智能语音服务学习教程
- 2024-11-22JAVA对接阿里云智能语音服务学习教程
- 2024-11-22Java对接阿里云智能语音服务学习教程
- 2024-11-22Java副业学习:零基础入门到实战项目
- 2024-11-22Java副业学习:零基础入门指南
- 2024-11-22Java微服务学习:入门与实践指南