css3實現橢圓軌跡旋轉
實現效果
X軸Y軸在一個矩形內移動
做斜線運動
1 .ball { 2 position: absolute; 3 animation: 4 animX 2s linear infinite alternate, 5 animY 2s linear infinite alternate 6 } 7 @keyframes animX{ 8 0% {left: 0px;} 9 100% {left: 500px;} 10 } 11 @keyframes animY{ 12 0% {top: 0px;} 13 100% {top: 300px;} 14 }
設置動畫延時
設置Y軸延時為動畫時長的一半, 運動軌跡變成菱形
1 .ball { 2 animation: 3 animX 2s linear 0s infinite alternate, 4 animY 2s linear -1s infinite alternate 5 }
設置三次貝塞爾曲線
1 .ball { 2 animation: 3 animX 2s cubic-bezier(0.36, 0, 0.64, 1) -1s infinite alternate, 4 animY 2s cubic-bezier(0.36, 0, 0.64, 1) 0s infinite alternate 5 }
縮小放大
為了看起來有立體感添加scale
屬性,scale動畫應該是X軸和Y軸的時間總和
1 .ball1 { 2 animation: 3 animX 2s cubic-bezier(0.36, 0, 0.64, 1) -1s infinite alternate, 4 animY 2s cubic-bezier(0.36, 0, 0.64, 1) 0s infinite alternate, 5 scale 4s cubic-bezier(0.36, 0, 0.64, 1) 0s infinite alternate; 6 } 7 @keyframes scale { 8 9 0% { 10 transform: scale(0.7) 11 } 12 50% { 13 transform: scale(1) 14 } 15 100% { 16 transform: scale(0.7) 17 } 18 }