zoukankan      html  css  js  c++  java
  • css3

    字体

    通过 CSS3,Web 设计师再也不必被迫使用“web-safe”字体了。

    <style>

    @font-face

    {

    font-family: myFirstFont;

    src: url('Sansation_Light.ttf'),

         url('Sansation_Light.eot'); /* IE9+ */

    }

    div

    {

    font-family:myFirstFont;

    }

    </style>

     

    2D

    通过 CSS3 转换,我们能够对元素进行移动、缩放、转动、拉长或拉伸。

    转换是使元素改变形状、尺寸和位置的一种效果。

    您可以使用 2D 或 3D 转换来转换您的元素

    translate()

    rotate()

    scale()

    skew()

    matrix()。

    translate()

    通过 translate() 方法,元素从其当前位置移动,根据给定的 left(x 坐标) 和 top(y 坐标) 位置参数:

    div

    {

    transform: translate(50px,100px);

    -ms-transform: translate(50px,100px);                     /* IE 9 */

    -webkit-transform: translate(50px,100px);             /* Safari and Chrome */

    -o-transform: translate(50px,100px);                        /* Opera */

    -moz-transform: translate(50px,100px);                  /* Firefox */

    }

    值 translate(50px,100px) 把元素从左侧移动 50 像素,从顶端移动 100 像素。

    rotate()

    通过 rotate() 方法,元素顺时针旋转给定的角度。允许负值,元素将逆时针旋转。

    div

    {

    transform: rotate(30deg);

    -ms-transform: rotate(30deg);                       /* IE 9 */

    -webkit-transform: rotate(30deg); /* Safari and Chrome */

    -o-transform: rotate(30deg);                          /* Opera */

    -moz-transform: rotate(30deg);                    /* Firefox */

    }

    scale()

    通过 scale() 方法,元素的尺寸会增加或减少,根据给定的宽度(X 轴)和高度(Y 轴)参数:

    div

    {

    transform: scale(2,4);

    -ms-transform: scale(2,4);   /* IE 9 */

    -webkit-transform: scale(2,4);          /* Safari 和 Chrome */

    -o-transform: scale(2,4);       /* Opera */

    -moz-transform: scale(2,4);               /* Firefox */

    }

    值 scale(2,4) 把宽度转换为原始尺寸的 2 倍,把高度转换为原始高度的 4 倍。

    skew()

    通过 skew() 方法,元素翻转给定的角度,根据给定的水平线(X 轴)和垂直线(Y 轴)参数:

    div

    {

    transform: skew(30deg,20deg);

    -ms-transform: skew(30deg,20deg);           /* IE 9 */

    -webkit-transform: skew(30deg,20deg);   /* Safari and Chrome */

    -o-transform: skew(30deg,20deg);              /* Opera */

    -moz-transform: skew(30deg,20deg);        /* Firefox */

    }

    值 skew(30deg,20deg) 围绕 X 轴把元素翻转 30 度,围绕 Y 轴翻转 20 度。

    matrix()

    matrix() 方法把所有 2D 转换方法组合在一起。

    matrix() 方法需要六个参数,包含数学函数,允许您:旋转、缩放、移动以及倾斜元素。

    div

    {

    transform:matrix(0.866,0.5,-0.5,0.866,0,0);

    -ms-transform:matrix(0.866,0.5,-0.5,0.866,0,0);                            /* IE 9 */

    -moz-transform:matrix(0.866,0.5,-0.5,0.866,0,0);           /* Firefox */

    -webkit-transform:matrix(0.866,0.5,-0.5,0.866,0,0);      /* Safari and Chrome */

    -o-transform:matrix(0.866,0.5,-0.5,0.866,0,0);                 /* Opera */

    }

    函数    描述

    matrix(n,n,n,n,n,n)    定义 2D 转换,使用六个值的矩阵。

    translate(x,y) 定义 2D 转换,沿着 X 和 Y 轴移动元素。

    translateX(n)  定义 2D 转换,沿着 X 轴移动元素。

    translateY(n)  定义 2D 转换,沿着 Y 轴移动元素。

    scale(x,y)         定义 2D 缩放转换,改变元素的宽度和高度。

    scaleX(n)          定义 2D 缩放转换,改变元素的宽度。

    scaleY(n)          定义 2D 缩放转换,改变元素的高度。

    rotate(angle)  定义 2D 旋转,在参数中规定角度。

    skew(x-angle,y-angle)            定义 2D 倾斜转换,沿着 X 和 Y 轴。

    skewX(angle) 定义 2D 倾斜转换,沿着 X 轴。

    skewY(angle) 定义 2D 倾斜转换,沿着 Y 轴。

    CSS3 过渡

    div

    {

    transition: width 2s;

    -moz-transition: width 2s;     /* Firefox 4 */

    -webkit-transition: width 2s;  /* Safari 和 Chrome */

    -o-transition: width 2s;       /* Opera */

    }

     

    div:hover
    {
    300px;
    }

     

     

     

    div
    {
    100px;
    height:100px;
    background:yellow;
    transition:width 2s, height 2s transform 2s;
    -moz-transition:width 2s, height 2s, -moz-transform 2s; /* Firefox 4 */
    -webkit-transition:width 2s, height 2s, -webkit-transform 2s; /* Safari and Chrome */
    -o-transition:width 2s, height 2s, -o-transform 2s; /* Opera */
    }div:hover
    {
    200px;
    height:200px;
    transform:rotate(180deg);
    -moz-transform:rotate(180deg); /* Firefox 4 */
    -webkit-transform:rotate(180deg); /* Safari and Chrome */
    -o-transform:rotate(180deg); /* Opera */
    }

     动画

     

    如需在 CSS3 中创建动画,您需要学习 @keyframes 规则。

    @keyframes 规则用于创建动画。在 @keyframes 中规定某项 CSS 样式,就能创建由当前样式逐渐改为新样式的动画效果。

    浏览器支持

    属性浏览器支持
    @keyframes          
    animation          

    Internet Explorer 10、Firefox 以及 Opera 支持 @keyframes 规则和 animation 属性。

    Chrome 和 Safari 需要前缀 -webkit-。

    注释:Internet Explorer 9,以及更早的版本,不支持 @keyframe 规则或 animation 属性。

    实例

    @keyframes myfirst
    {
    from {background: red;}
    to {background: yellow;}
    }
    
    @-moz-keyframes myfirst /* Firefox */
    {
    from {background: red;}
    to {background: yellow;}
    }
    
    @-webkit-keyframes myfirst /* Safari 和 Chrome */
    {
    from {background: red;}
    to {background: yellow;}
    }
    
    @-o-keyframes myfirst /* Opera */
    {
    from {background: red;}
    to {background: yellow;}
    }
    

    CSS3 动画

    当您在 @keyframes 中创建动画时,请把它捆绑到某个选择器,否则不会产生动画效果。

    通过规定至少以下两项 CSS3 动画属性,即可将动画绑定到选择器:

    • 规定动画的名称
    • 规定动画的时长

    实例

    把 "myfirst" 动画捆绑到 div 元素,时长:5 秒:

    div
    {
    animation: myfirst 5s;
    -moz-animation: myfirst 5s;	/* Firefox */
    -webkit-animation: myfirst 5s;	/* Safari 和 Chrome */
    -o-animation: myfirst 5s;	/* Opera */
    }
    

    亲自试一试

    注释:您必须定义动画的名称和时长。如果忽略时长,则动画不会允许,因为默认值是 0。

    什么是 CSS3 中的动画?

    动画是使元素从一种样式逐渐变化为另一种样式的效果。

    您可以改变任意多的样式任意多的次数。

    请用百分比来规定变化发生的时间,或用关键词 "from" 和 "to",等同于 0% 和 100%。

    0% 是动画的开始,100% 是动画的完成。

    为了得到最佳的浏览器支持,您应该始终定义 0% 和 100% 选择器。

    实例

    当动画为 25% 及 50% 时改变背景色,然后当动画 100% 完成时再次改变:

    @keyframes myfirst
    {
    0%   {background: red;}
    25%  {background: yellow;}
    50%  {background: blue;}
    100% {background: green;}
    }
    
    @-moz-keyframes myfirst /* Firefox */
    {
    0%   {background: red;}
    25%  {background: yellow;}
    50%  {background: blue;}
    100% {background: green;}
    }
    
    @-webkit-keyframes myfirst /* Safari 和 Chrome */
    {
    0%   {background: red;}
    25%  {background: yellow;}
    50%  {background: blue;}
    100% {background: green;}
    }
    
    @-o-keyframes myfirst /* Opera */
    {
    0%   {background: red;}
    25%  {background: yellow;}
    50%  {background: blue;}
    100% {background: green;}
    }
    

    亲自试一试

    实例

    改变背景色和位置:

    @keyframes myfirst
    {
    0%   {background: red; left:0px; top:0px;}
    25%  {background: yellow; left:200px; top:0px;}
    50%  {background: blue; left:200px; top:200px;}
    75%  {background: green; left:0px; top:200px;}
    100% {background: red; left:0px; top:0px;}
    }
    
    @-moz-keyframes myfirst /* Firefox */
    {
    0%   {background: red; left:0px; top:0px;}
    25%  {background: yellow; left:200px; top:0px;}
    50%  {background: blue; left:200px; top:200px;}
    75%  {background: green; left:0px; top:200px;}
    100% {background: red; left:0px; top:0px;}
    }
    
    @-webkit-keyframes myfirst /* Safari 和 Chrome */
    {
    0%   {background: red; left:0px; top:0px;}
    25%  {background: yellow; left:200px; top:0px;}
    50%  {background: blue; left:200px; top:200px;}
    75%  {background: green; left:0px; top:200px;}
    100% {background: red; left:0px; top:0px;}
    }
    
    @-o-keyframes myfirst /* Opera */
    {
    0%   {background: red; left:0px; top:0px;}
    25%  {background: yellow; left:200px; top:0px;}
    50%  {background: blue; left:200px; top:200px;}
    75%  {background: green; left:0px; top:200px;}
    100% {background: red; left:0px; top:0px;}
    }
    

    亲自试一试

    CSS3 动画属性

    下面的表格列出了 @keyframes 规则和所有动画属性:

    属性描述CSS
    @keyframes 规定动画。 3
    animation 所有动画属性的简写属性,除了 animation-play-state 属性。 3
    animation-name 规定 @keyframes 动画的名称。 3
    animation-duration 规定动画完成一个周期所花费的秒或毫秒。默认是 0。 3
    animation-timing-function 规定动画的速度曲线。默认是 "ease"。 3
    animation-delay 规定动画何时开始。默认是 0。 3
    animation-iteration-count 规定动画被播放的次数。默认是 1。 3
    animation-direction 规定动画是否在下一周期逆向地播放。默认是 "normal"。 3
    animation-play-state 规定动画是否正在运行或暂停。默认是 "running"。 3
    animation-fill-mode 规定对象动画时间之外的状态。 3

    下面的两个例子设置了所有动画属性:

    实例

    运行名为 myfirst 的动画,其中设置了所有动画属性:

    div
    {
    animation-name: myfirst;
    animation-duration: 5s;
    animation-timing-function: linear;
    animation-delay: 2s;
    animation-iteration-count: infinite;
    animation-direction: alternate;
    animation-play-state: running;
    /* Firefox: */
    -moz-animation-name: myfirst;
    -moz-animation-duration: 5s;
    -moz-animation-timing-function: linear;
    -moz-animation-delay: 2s;
    -moz-animation-iteration-count: infinite;
    -moz-animation-direction: alternate;
    -moz-animation-play-state: running;
    /* Safari 和 Chrome: */
    -webkit-animation-name: myfirst;
    -webkit-animation-duration: 5s;
    -webkit-animation-timing-function: linear;
    -webkit-animation-delay: 2s;
    -webkit-animation-iteration-count: infinite;
    -webkit-animation-direction: alternate;
    -webkit-animation-play-state: running;
    /* Opera: */
    -o-animation-name: myfirst;
    -o-animation-duration: 5s;
    -o-animation-timing-function: linear;
    -o-animation-delay: 2s;
    -o-animation-iteration-count: infinite;
    -o-animation-direction: alternate;
    -o-animation-play-state: running;
    }
    

    亲自试一试

    实例

    与上面的动画相同,但是使用了简写的动画 animation 属性:

    div
    {
    animation: myfirst 5s linear 2s infinite alternate;
    /* Firefox: */
    -moz-animation: myfirst 5s linear 2s infinite alternate;
    /* Safari 和 Chrome: */
    -webkit-animation: myfirst 5s linear 2s infinite alternate;
    /* Opera: */
    -o-animation: myfirst 5s linear 2s infinite alternate;
    }

     

  • 相关阅读:
    python中的zip()函数和map()函数
    Unity3d插件推荐
    使用Unity3d的Physics.Raycast()的用法做子弹射击
    Unity3D集成SVN进行版本控制
    WVGA-维基百科
    Unity3D之如何创建正确的像素比在屏幕上
    Unity3D如何获取对象和子对象
    Thread: BooleanRT : Realtime 3D boolean operations for (Runtime,Editor)
    Unity3D GUI中的图片跟随鼠标旋转脚本
    三维软件转Unity的系统单位设置研究
  • 原文地址:https://www.cnblogs.com/xuyanjiayou/p/8488453.html
Copyright © 2011-2022 走看看