CSS3 transform变形(3D转换)

Stella981
• 阅读 647

一.三维坐标

空间中三维坐标如下图所示:

向上为-Y,向下为+Y,向左为-X,向右为+X,向前为+Z,向后为-Z。

  CSS3 transform变形(3D转换)

二.perspective(n)为 3D 转换元素定义透视视图

perspective的中文意思是:透视,视角。

没有透视定义,不成3D。

下图为透视的一张图:

CSS3 transform变形(3D转换)

CSS3中3D transform的透视点是在浏览器的前方!

需要设置该元素或该元素父辈元素的perspective大小。

perspective(n)定义视点离屏幕的距离。

三.translate3d(x,y,z),translateX(x),translateY(y),translateZ(z)定义3D平移转换

1.translate3d(x,y,z)定义3D平移,x,y,z分别为移动的位移。

如下代码中,设置父元素的perspective( )为1000px,x,y,x值分别设置为100px,100px,100px。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>CSS3</title>
    <style type="text/css">
        .father{
            -webkit-perspective: 1000px;
            -moz-perspective: 1000px;
            perspective: 1000px;
        }
        div
        {
            width:120px;
            height:75px;
            background-color:red;
            border:1px solid black;
        }
        div#div2
        {
            -webkit-transform:translate3d(100px,100px,100px); /* Safari and Chrome */
            -moz-transform:translate3d(100px,100px,100px); /* Firefox */
            transform:translate3d(100px,100px,100px);
        }
    </style>
</head>
<body>
<div class="father">
<div>ORIGINAL</div>
<div id="div2">TRANSFORMED</div>
</div>
</body>
</html>

效果如下图所示:

  CSS3 transform变形(3D转换)

2.translateX(x),定义平移转换,只用X轴的值。

如下代码中,设置translateX( )值为100px。

  div#div2
        {
            -webkit-transform:translateX(100px); /* Safari and Chrome */
            -moz-transform:translateX(100px); /* Firefox */
            transform:translateX(100px);
        }

  效果如下图所示:

  CSS3 transform变形(3D转换)

3.translateY(y),定义平移转换,只用Y轴的值。

如下代码中,设置translateY( )值为100px。

   div#div2
        {
            -webkit-transform:translateY(100px); /* Safari and Chrome */
            -moz-transform:translateY(100px); /* Firefox */
            transform:translateY(100px);
        }

   效果如下图所示:

  CSS3 transform变形(3D转换)

4.translateZ(z)定义平移转换,只用Z轴的值。

定义translateZ( ),必须要先定义perspective值,否则没有效果。

translateZ( )的功能就是让元素在自己的眼前或近或远。

设置的translateZ( )值越小,则子元素越小(因为元素远去,我们眼睛看到的就会变小),translateZ( )值越大,该元素也会越来越大。

translateZ( )值接近于perspective值时,该元素的大小就会撑满整个屏幕。

如下代码中,设置父元素的perspective( )为1000px,translateZ( )值为120px。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>CSS3</title>
    <style type="text/css">
        .father{
            -webkit-perspective: 1000px;
            -moz-perspective: 1000px;
            perspective: 1000px;
        }
        div
        {
            width:120px;
            height:75px;
            background-color:red;
            border:1px solid black;
        }
        div#div2
        {
            -webkit-transform:translateZ(120px); /* Safari and Chrome */
            -moz-transform:translateZ(120px); /* Firefox */
            transform:translateZ(120px);
        }
    </style>
</head>
<body>
<div class="father">
<div>ORIGINAL</div>
<div id="div2">TRANSFORMED</div>
</div>
</body>
</html>

  效果如下图所示:

  CSS3 transform变形(3D转换)

四.rotate3d(x,y,z,angle),rotateX(angle),rotateY(angle),rotateZ(angle)定义3D旋转

1.rotate3d(x,y,z,angle)定义3D旋转。

x:是一个0到1之间的数值,主要用来描述元素围绕X轴旋转的矢量值;

y:是一个0到1之间的数值,主要用来描述元素围绕Y轴旋转的矢量值;

z:是一个0到1之间的数值,主要用来描述元素围绕Z轴旋转的矢量值;

angle:是一个角度值,主要用来指定元素在3D空间旋转的角度,如果其值为正值表示元素顺时针旋转,为负值表示元素逆时针旋转。

如下代码中,设置x,y,z均为1,angle为30deg。

 div#div2
        {
            -webkit-transform:rotate3d(1,1,1,30deg); /* Safari and Chrome */
            -moz-transform:rotate3d(1,1,1,30deg); /* Firefox */
            transform:rotate3d(1,1,1,30deg);
        }

  效果如下图所示:

  CSS3 transform变形(3D转换)

2. rotateX(angle),定义沿着X轴的3D旋转

rotateX(angle)表示以X轴为旋转轴旋转。

rotateX(angle)函数功能等同于rotate3d(1,0,0,angle)。

如下代码中,设置angle为40deg。

  div#div2
        {
            -webkit-transform:rotateX(40deg); /* Safari and Chrome */
            -moz-transform:rotateX(40deg); /* Firefox */
            transform:rotateX(40deg);
        }

  效果如下图所示:

  CSS3 transform变形(3D转换)

  3. rotateY(angle),定义沿着Y轴的3D 旋转

rotateY(angle)表示以Y轴为旋转轴旋转。

rotateY(angle)函数功能等同于rotate3d(0,1,0,angle)。

如下代码中,设置angle为40deg。

div#div2
        {
            -webkit-transform:rotateY(40deg); /* Safari and Chrome */
            -moz-transform:rotateY(40deg); /* Firefox */
            transform:rotateY(40deg);
        }

  效果如下图所示:

CSS3 transform变形(3D转换)

  4. rotateZ(angle),定义沿着Z轴的3D旋转

rotateZ(angle)表示以Z轴为旋转轴旋转。

rotateZ(angle)函数功能等同于rotate3d(0,0,1,angle)。

如下代码中,设置angle为40deg。

div#div2
        {
            -webkit-transform:rotateZ(40deg); /* Safari and Chrome */
            -moz-transform:rotateZ(40deg); /* Firefox */
            transform:rotateZ(40deg);
        }

  效果如下图所示:

CSS3 transform变形(3D转换)

五.scale3d(x,y,z),scaleX(x),scaleY(y),scaleZ(z)定义3D缩放转换

1.scale3d(x,y,z)通过使用3D缩放函数,可以让元素在Z轴上按比例缩放。

默认值为1,当值大于1时,元素放大,反之小于1大于0.01时,元素缩小。

当scale3d()中x和y值同时为1,即scale3d(1,1,z),其效果等同于scaleZ(z)。

如下代码中,设置x值为2,y值为2,z值为1。

    div#div2
        {
            -webkit-transform:scale3d(2,2,1); /* Safari and Chrome */
            -moz-transform:scale3d(2,2,1); /* Firefox */
            transform:scale3d(2,2,1);
        }

  效果如下图所示:

CSS3 transform变形(3D转换)

  2.scaleX(x)通过设置X轴的值来定义缩放转换。

scaleX(x)使元素的宽变成原来的x倍。

如下代码中,设置scaleX( )值为2。

   div#div2
        {
            -webkit-transform:scaleX(2); /* Safari and Chrome */
            -moz-transform:scaleX(2); /* Firefox */
            transform:scaleX(2);
        }

效果如下图所示:

CSS3 transform变形(3D转换)

3.scaleY(y)通过设置Y轴的值来定义缩放转换。

scaleY(y)使元素的高变成原来的y倍。

如下代码中,设置scaleY( )值为2。

div#div2
        {
            -webkit-transform:scaleY(2); /* Safari and Chrome */
            -moz-transform:scaleY(2); /* Firefox */
            transform:scaleY(2);
        }

效果如下图所示:

CSS3 transform变形(3D转换)

4.scaleZ(z)通过设置Z轴的值来定义缩放转换。

  scaleZ( )和scale3d( )函数单独使用时没有任何效果,需要配合其他的变形函数一起使用才会有效果。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
JS 苹果手机日期显示NaN问题
问题描述newDate("2019122910:30:00")在IOS下显示为NaN原因分析带的日期IOS下存在兼容问题解决方法字符串替换letdateStr"2019122910:30:00";datedateStr.repl
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
暗箭伤人 暗箭伤人
1年前
【www.ithunter.club】 20230922下午
不容易的2023年,我们一起努力【www.ithunter.club】(2023092208:00:00.8872062023092216:00:00.887206)1.人事招聘专员数名(可选远程或入职)2.招聘向坐标东京Yahoo、Shift、L
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这