# Rotating Border Animation Effects [竹白記事本](https://chupainotebook.blogspot.com/2019/02/css-effect.html),學習紀錄,2019/03/22。 >[CSS Rotating Border Animation Effects - Border Animation Using CSS3 Keyframes ](https://www.youtube.com/watch?v=t-9UIPEJxxQ) ###### tags: `animation` `transform` `pointer-events` ## CodePen >[Rotating Border Animation Effects](https://codepen.io/chupai/pen/XGxRgL) <iframe height="265" style="width: 100%;" scrolling="no" title="Rotating Border Animation Effects" src="//codepen.io/chupai/embed/XGxRgL/?height=265&theme-id=0&default-tab=result" frameborder="no" allowtransparency="true" allowfullscreen="true"> See the Pen <a href='https://codepen.io/chupai/pen/XGxRgL/'>Rotating Border Animation Effects</a> by Chupai@Design (<a href='https://codepen.io/chupai'>@chupai</a>) on <a href='https://codepen.io'>CodePen</a>. </iframe> ## transform >[transform|MDN](https://developer.mozilla.org/zh-TW/docs/Web/CSS/transform) `transform` CSS 屬性可以讓你修改 CSS 可視化格式糢型(visual formatting model)的空間維度。使用此屬性,元素可以被平移、旋轉、縮放和傾斜。 - `translate(x,y)`,元素水平、垂直移動。 - `translateX(x)`,元素水平移動。 - `translateY(y)`,元素垂直移動。 - `scale(x,y)`,元素縮放。 - `scaleX(x)`,元素水平方向縮放。 - `scaleY(y)`,元素垂直方向縮放。 - `rotate(angle)`,元素旋轉的角度。 - `skew(x-angle,y-angle)`,元素傾斜設定。 - `skewX(angle)`,元素水平傾斜設定。 - `skewY(angle)`,元素垂直傾斜設定。 - `matrix(n,n,n,n,n,n)`,以含有 6 個參數值的變化定元素的變形效果。 - `none`,不進行任何變換。 ## transform-origin `transform-origin` 屬性為複合屬性值,其屬性包含水平(X 軸),與垂直(Y軸),方向的變量參數,變量參數間以空白隔開。如果只給一個數值,則變更水平(X 軸),垂直(Y軸)不變。 可用屬性值: - 長度,數值 + 單位 - `%`(百分比),以元素預設中間的點的基準為百分比值。 - `left`,靠左,水平方向位置的選項,等同 `0%`。 - `right`,靠右,水平方向位置的選項,等同 `100%`。 - `top`,靠上,垂直方向位置的選項,等同 `0%`。 - `bottom`,靠下,垂直方向位置的選項,等同 `100%`。 - `center`,置中, 水平、垂直方向位置的選項,等同 `50%`。 ## animation 屬性 >[animation|MDN](https://developer.mozilla.org/zh-CN/docs/Web/CSS/animation) >[完整解析 CSS 動畫|Oxxo Studio](https://www.oxxostudio.tw/articles/201803/css-animation.html) CSS `animation` 屬性是如下屬性的一個簡寫屬性形式: - `animation-name`,指定動畫名稱。 - `animation-duration`,指定動畫撥出時間。 - `animation-timing-function`,指定動畫撥放的速度。 - `animation-delay`,設定動畫延遲播放時間。 - `animation-iteration-count`,設定動畫播放次數。 - `animation-direction`,設定動畫播放方向。 - `animation-fill-mode`,設定動畫播放前後模式。 - `animation-play-state`,動畫播放或暫停狀態。 ### **`animation-name`** 指定應用的一系列動畫,每個名稱代表一個由 [`@keyframes`](#keyframes) 定義的動畫序列。 ### **`animation-duration`** 動畫撥出的持續時間,數值加上單位 `s` 秒或 `ms` 毫秒,如果時間為負數等同 0 秒,不會進行動畫。 ### **`animation-timing-function`** - `ease`,平滑播放(逐漸變慢)。 - `ease-in`,慢到快(加速)。 - `ease-out`,快到慢(減速)。 - `ease-in-out`,慢到快再到慢(先加速後再減速)。 - `linear`,線性播放(等速)。 - `step-start`、`step-end`,按照關鍵影格的順序一格格進行,不會有中間的演算動畫,兩者差異在於,前者看不到第一格,後者看不到最後一格。 - `cubic-bezier()`,自定義速度。 ### **`animation-delay`** 設定動畫延遲播放時間,數值加上單位 `s` 秒或 `ms` 毫秒,如果時間為負數則是快轉。 ### **`animation-iteration-count`** 動畫播放的次數,預設值為 1 次。 - 次數,指定播放次數。 - `infinite`,無限循環。 ### **`animation-direction`** - `normal`,正常播放,從 0% 到 100%(預設值)。 - `reverse`,反轉播放,從 100% 到 0%。 - `alternate`,正反轉輪流播放,奇數次為 0% 到 100%,偶數次為 100% 到 0%,若動畫播放次數只有一次就只會正常播放。 - `alternate-reverse`,`alternate` 的相反,奇數次為 100% 到 0%,偶數次為 0% 到 100%,若動畫播放次數只有一次就只會反轉播放。 ### **`animation-fill-mode`** 動畫播放前後模式。 - `none`,預設值,不論動畫播放次數,結束後一律返回原始狀態。 - `forwards`,動畫結束後,保持在最後一個影格狀態。 - `backwards`,動畫結束後,保持在第一個影格狀態(但實際測試和 none 效果一樣)。 - `both`,依據動畫的次數或播放方向,保持在第一個影格或最後一個影格狀態,相當實用。 ### **`animation-play-state`** 動畫播放或暫停狀態。 - `running`:,預設值,表示動畫運行。 - `paused`,表示動畫暫停。 ## @keyframes 設定關鍵影格 ```css @keyframes 動畫名稱 {屬性設定;} ``` 屬性設定: 1. `from`,動畫第 1 個影格效果設定,等同 0%。 2. `to`,動畫最後 1 個格影格效果設定,等同 100%。 3. `%`,以動畫撥出時間的百分比,進行特定影格設定。 ## pointer-events 為控制滑鼠目標的屬性。 - `auto`,預設值。 - `none`,穿透。 範例:[CodePen](https://codepen.io/CHUPAIWANG/pen/aMoxqp) <iframe height="321" style="width: 100%;" scrolling="no" title="pointer-events" src="//codepen.io/CHUPAIWANG/embed/aMoxqp/?height=321&theme-id=0&default-tab=result" frameborder="no" allowtransparency="true" allowfullscreen="true"> See the Pen <a href='https://codepen.io/CHUPAIWANG/pen/aMoxqp/'>pointer-events</a> by CHUPAIWANG (<a href='https://codepen.io/CHUPAIWANG'>@CHUPAIWANG</a>) on <a href='https://codepen.io'>CodePen</a>. </iframe> 有加上 `pointer-events: none;` 的元素變得可以穿透,並且無法選取,類似幽靈的狀態。