如何用一个div画一个太极图

2018-10-20  本文已影响61人  夜未央_M

定义一个id为taiji的 div

<!DOCTYPE html>
<html lang="en">
<head>
    <link rel="stylesheet" href="css/taiji.css">
    <title>Document</title>

</head>
<body>
    <div id="taiji"></div>
    <p>道生一,一生二,二生三,三生万物</p>
</body>
</html>

body{
    background-color:#666
  }
  
  @keyframes spin{
    from{
      transform: rotate(0deg);
    }
    to{
      transform: rotate(360deg);
    }
  }

  
  #taiji{
    width:200px;
    height:200px;
    border-radius:50%;
    background: linear-gradient(to bottom, #fff 0%,#fff 50%,#000 50%,#000 100%); 
    position: relative;
    margin: 100px auto 20px;
    animation: spin 3s linear 0s  infinite;
  }
/*

animation定义和用法
animation 属性是一个简写属性,用于设置六个动画属性:
animation-name
animation-duration
animation-timing-function
animation-delay
animation-iteration-count
animation-direction
默认值:    none 0 ease 0 1 normal    

注意!!!:请始终规定 animation-duration 属性,否则时长为 0,就不会播放动画了。

语法

animation: name duration timing-function delay iteration-count direction;

animation-name                规定需要绑定到选择器的 keyframe 名称。。    
animation-duration            规定完成动画所花费的时间,以秒或毫秒计。    
animation-timing-function     规定动画的速度曲线。    
animation-delay               规定在动画开始之前的延迟。    
animation-iteration-count     规定动画应该播放的次数。(值:n次,infinite无限循环)    
animation-direction           规定是否应该轮流反向播放动画。   

animation-timing-function  的值:
linear                      动画从头到尾的速度是相同的。  测试
ease                        默认。动画以低速开始,然后加快,在结束前变慢。 测试
ease-in                   动画以低速开始。  测试
ease-out                    动画以低速结束。    测试
ease-in-out               动画以低速开始和结束。   测试
cubic-bezier(n,n,n,n)       在 cubic-bezier 函数中自己的值。可能的值是从 0 到 1 的数值。

总结:
根据上述属性,只需要根据具体情况设置animation-delay和animation-iteration-count即可。

例如:


div
{
animation:mymove 5s 5s infinite;
-webkit-animation:mymove 5s 5s infinite; /* Safari 和 Chrome */

  
  #taiji::before{ /*利用元素的伪类特性*/
    
    content: '';  /* 很重要!!! 伪类默认不出现,必须给一个content才可以出现 */
    width: 20px; 
    height: 20px;
    border-radius: 50%;
    background: #FFF;
    position: absolute; /*套路:!!! 绝对定位后自动变为block */
    top: 50px;
    left: 0;
    border: 40px solid #000; /*这里也可以用渐变,也可以用描边*/
  }
  
  
  #taiji::after{ /*利用元素的伪类特性*/
    
    content: '';  /* 很重要!!! 伪类默认不出现,必须给一个content才可以出现 */
    width: 20px; 
    height: 20px;
    border-radius: 50%;
    background: #000;
    position: absolute; /*套路:!!! 绝对定位后自动变为block */
    top: 50px;
    right: 0;
    border: 40px solid #FFF;
  }
  

  p{
    color: white;
    text-align: center;
  }

上一篇 下一篇

猜你喜欢

热点阅读