##transform(变形)、闹钟实例、3D

国外测试网站:http://codepen.io/

transform(变形)

CSS3中可以通过transform属性修改元素的变形、旋转、缩放、倾斜特性,在CSS3中transform主要包括以下几种:旋转rotate、倾斜skew、缩放scale和移动translate以及矩阵变形matrix
transform-origin的取值可以是top, bottom, left, right, center, 或百分比,或长度值

参数
rotate(旋转)

可以通过rotate使元素旋转一定的度数

transform:rotate(30deg);
顺时针旋转一定角度, 单位是角度deg(degree)
旋转之后元素仍占据原来位置,实际上所有的transform都是这样,缩放、位移等都不会改变元素占据的位置
元素旋转的的基点默认是中心(坐标轴原点),可以通过transform-origin属性改变
transform:rotate(30deg); 
transform-origin: 0% 0%;
transform-origin的取值可以是top, bottom, left, right, center, 或百分比,或长度值

transform-origin属性对下面介绍的transform都有作用

translate(位移)

可以通过translate使元素平移

transform:translate(x,y);
例子

transform:translate(200px,150px);
也可以简单只移动一个坐标

transform:translateX(100px);
transform:translateY(100px);

scale(缩放)

可以通过scale使元素缩放一定的比例,和translate类似,也有三个方法

scale(x,y) /*使元素水平方向和垂直方向同时缩放*/
scaleX(x) /*元素仅水平方向缩放*/
scaleY(y) /*元素仅垂直方向缩放*/
transform:scale(2, 0.5);
transform:scaleY(0.3);
transform:scaleY(2);
transform:scale(3);

skew(倾斜)

可以通过skew使元素扭曲一定的度数,和上面一样也有三中类似的用法

transform:skew(10deg, 20deg);
transform:skewX(10deg);
transform:skewY(10deg);
transform:skew(10deg);

transform应用,时钟完整代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
    *{
        margin:0;
        padding:0;
    }
    .clock{
        background: #000;
        width:200px;
        height: 200px;
        margin:0 auto;
        border-radius: 50%;
        position: relative;

    }
    .circle{
        position: absolute;
        width:20px;
        height: 20px;
        border-radius: 50%;
        background: #fff;
        left: 50%;
        top:50%;
        margin-top:-10px;
        margin-left: -10px;
        z-index: 50;
    }
    .hour-line{
        position: absolute;
        width:40px;
        height: 10px;
        background:red;
        left: 50%;
        top:50%;
        margin-top:-5px;
        border-radius: 5px;
        transform-origin:0 50%;
        z-index: 1;
    }
    .min-line{
        position: absolute;
        width:50px;
        height: 8px;
        background:#454;
        left: 50%;
        top:50%;
        margin-top:4px;
        border-radius: 5px;
        transform-origin:0 50%;
        z-index: 1;
    }
    .sec-line{
        position: absolute;
        width:60px;
        height: 4px;
        background:#8ac;
        left: 50%;
        top:50%;
        margin-top:-2px;
        border-radius: 1px;
        transform-origin:0 50%;
        z-index: 1;
    }
    .hours div{
        position: absolute;
        width: 20px;
        height: 2px;
        background:red;
        left: 50%;
        top:50%;
        margin-top:-1px;
        margin-left:-10px;
        border-radius: 1px;
    }
    .mins div{
        position: absolute;
        width:8px;
        height: 2px;
        background:red;
        left: 50%;
        top:50%;
        margin-top:-1px;
        margin-left:-4px;
        border-radius: 1px;
    }
    </style>
</head>
<body>
    <div class="clock">
        <!-- 圆心 -->
        <div class="circle"></div>
        <!-- 指针 -->
        <div class="hour-line"></div>
        <div class="min-line"></div>
        <div class="sec-line"></div>
        <!-- 刻度 -->
        <div class="hours"></div>
        <div class="mins"></div>

    </div>
    <script>
        var hours=document.querySelector('.hours');
        var mins=document.querySelector('.mins');
        //生成时间刻度
        var hourStr='';
        for(var i=0;i<12;i++){
            hourStr+='<div style="transform: rotate('+(-90+i*30)+'deg) translate(85px);"></div>'
        }
        hours.innerHTML=hourStr;
        var minStr='';
        for(var i=0;i<60;i++){
            minStr+='<div style="transform: rotate('+(-90+i*6)+'deg) translate(90px);"></div>'
        }
        mins.innerHTML=minStr;
        
        //获取时间指针
            var hourLine=document.querySelector('.hour-line');
            var minLine=document.querySelector('.min-line');
            var secLine=document.querySelector('.sec-line');
        //封装指针旋转角度函数
        function drawClock(){
            //获取当前时间
            var now=new Date();
            var hour=now.getHours();
            var min=now.getMinutes();
            var sec=now.getSeconds();
            hourLine.style.transform='rotate('+(-90+hour*30+(min/60)*6)+'deg)';
            minLine.style.transform='rotate('+(-90+min*6+(sec/60)*6)+'deg)';
            secLine.style.transform='rotate('+(-90+sec*6)+'deg)';
        }
        drawClock();
        //开启定时器
        setInterval(function(){
            drawClock();
        }, 1000);

    </script>
</body>
</html>

transform 3D 效果

相关函数

旋转 rotateX() rotatY() rotateZ()
位移 translateZ()
缩放 scaleZ()

perspective

在父级设置睛生perspective:500px;
perspective属性的值决定了3D效果的强烈程度,可以认为是观察者到页面的距离。值越大距离越远,视觉上的3D效果就会相应的减弱。perspective: 2000px; 会产生一个好像我们使用望远镜看远方物体的3D效果,perspective: 100px;会产生一个小昆虫看大象的效果。

perspective-origin //设置消失的位置
在父级设置perspective-origin: 0 0;
定义了消失点的位置,如当你沿着铁路线去看两条铁轨,沿着公路线去看两边排列整齐的树木时,两条平行的铁轨或两排树木连线交与很远很远的某一点,这点在透视图中叫做消失点。

backface-visibility
子元素上设置backface-visibility:hidden;

backface-visibility属性指定当元素背面朝向观察者时是否可见。元素的背面总是透明的,当其朝向观察者时,显示正面的镜像。

在某些情况下,我们不希望元素内容在背面可见,比如实现翻牌效果。
transform-style
在父级设置transform-style: preserve-3d;
transform-style属性指定了,该元素的子元素是(看起来)位于三维空间内,还是在该元素所在的平面内被扁平化。

如果被扁平化,则子元素不会独立的存在于三维空间。

在元素本身设置旋转的中心点transform-origin: center center 100px;

正方体

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        .cube{
            position: relative;
            width:200px;
            height: 200px;
            margin:200px auto;
            perspective:4000px;
            transition: all 1s;
            transform-style: preserve-3d;/*使里面的div有3D效果*/
            transform-origin: center center 100px;
            transform: rotateY(30deg);/*旋转*/
            transform: skew(30deg);/*倾斜*/
            
        }
        .cube:hover{

            transform: rotateY(180deg);

        }
        .cube div{
            position: absolute;
            width:200px;
            height: 200px;
            color: #c3c;
            font-size: 60px;
            text-align: center;
            line-height: 200px;
        }
        .cube div:nth-child(1){
            transform-origin:right center;
            transform:translateX(-200px) rotateY(90deg); 
            background:rgba(23,222,10,.6);
        }
        .cube div:nth-child(2){
            transform-origin:left center;
            transform:translateX(200px) rotateY(-90deg); 
            background:rgba(23,11,10,.6);
        }
        .cube div:nth-child(3){
            transform-origin:bottom center;
            transform:translateY(-200px) rotateX(-90deg); 
            background:rgba(23,66,10,.6);
        }
        .cube div:nth-child(4){
            transform-origin:top center;
            transform:translateY(200px) rotateX(90deg); 
            background:rgba(23,123,10,.6);
        }
        .cube div:nth-child(5){
            transform:translateZ(200px); 
            background:rgba(23,211,10,.6);
        }
        .cube div:nth-child(6){
            background:rgba(23,45,11,.6);
        }

    </style>
</head>
<body>
    <div class="cube">
        <div class="side-1">1</div>
        <div class="side-2">2</div>
        <div class="side-3">3</div>
        <div class="side-4">4</div>
        <div class="side-5">5</div>
        <div class="side-6">6</div>
    </div>
</body>
</html>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容

  • 关于css3变形 CSS3变形是一些效果的集合,比如平移、旋转、缩放和倾斜效果,每个效果都被称作为变形函数(Tra...
    hopevow阅读 6,322评论 2 13
  • CSS里transform变形这个属性有点学习难度,尤其在CSS3里加上了3D效果之后,2维变3维学习成本更是成倍...
    张歆琳阅读 27,775评论 5 81
  • 看了很多视频、文章,最后却通通忘记了,别人的知识依旧是别人的,自己却什么都没获得。此系列文章旨在加深自己的印象,因...
    DCbryant阅读 1,858评论 0 4
  • CSS的变形对应的属性是transform,它的作用是修改元素自身的坐标空间。这个修改实际对应了一个坐标系统映射转...
    荷小音阅读 1,080评论 1 5
  • 我就没见过 这么炽热的夏天 她让我看清楚她的风景 可我只看见她没有穿衣服
    简村小吹阅读 443评论 31 20