## filter(濾鏡) 屬性
### 定義和使用
filter 屬性定義了元素(通常是)的可視效果(例如:模糊與飽和度)。
JavaScript 語法:object.style.WebkitFilter="grayscale(100%)" 嘗試一下 ?
* * *
## CSS 語法
~~~
filter: none | blur() | brightness() | contrast() | drop-shadow() | grayscale() | hue-rotate() | invert() | opacity() | saturate() | sepia() | url();
~~~
**提示:**使用空格分隔多個濾鏡。
* * *
## Filter 函數
**注意:**濾鏡通常使用百分比 (如:75%), 當然也可以使用小數來表示 (如:0.75)。
| Filter | 描述 |
| --- | --- |
| none | 默認值,沒有效果。 |
| blur(*px*) | 給圖像設置高斯模糊。"radius"一值設定高斯函數的標準差,或者是屏幕上以多少像素融在一起, 所以值越大越模糊; 如果沒有設定值,則默認是0;這個參數可設置css長度值,但不接受百分比值。 |
| brightness(*%*) | 給圖片應用一種線性乘法,使其看起來更亮或更暗。如果值是0%,圖像會全黑。值是100%,則圖像無變化。其他的值對應線性乘數效果。值超過100%也是可以的,圖像會比原來更亮。如果沒有設定值,默認是1。 |
| contrast(*%*) | 調整圖像的對比度。值是0%的話,圖像會全黑。值是100%,圖像不變。值可以超過100%,意味著會運用更低的對比。若沒有設置值,默認是1。 |
| drop-shadow(*h-shadow v-shadow blur spread color*) | 給圖像設置一個陰影效果。陰影是合成在圖像下面,可以有模糊度的,可以以特定顏色畫出的遮罩圖的偏移版本。 函數接受(在CSS3背景中定義)類型的值,除了"inset"關鍵字是不允許的。該函數與已有的box-shadow box-shadow屬性很相似;不同之處在于,通過濾鏡,一些瀏覽器為了更好的性能會提供硬件加速。`<shadow>參數如下:`** **(必須)這是設置陰影偏移量的兩個 值.****?設定水平方向距離. 負值會使陰影出現在元素左邊.****設定垂直距離.負值會使陰影出現在元素上方。查看****可能的單位. **如果兩個值都是0**, 則陰影出現在元素正后面 (如果設置了``<blur-radius>?and/or?`<spread-radius>,會有模糊效果).` ``****(可選)這是第三個code>值. 值越大,越模糊,則陰影會變得更大更淡.不允許負值 若未設定,默認是0?(則陰影的邊界很銳利).***(可選)這是第四個 值. 正值會使陰影擴張和變大,負值會是陰影縮小.若未設定,默認是0?(陰影會與元素一樣大小).? 注意: Webkit, 以及一些其他瀏覽器 不支持第四個長度,如果加了也不會渲染。****(可選)查看 該值可能的關鍵字和標記。若未設定,顏色值基于瀏覽器。Gecko?(Firefox), Presto (Opera)和Trident (Internet Explorer)中, 會應用color**color**屬性的值。另外, 如果顏色值省略,WebKit中陰影是透明的。|
| grayscale(*%*) | 將圖像轉換為灰度圖像。值定義轉換的比例。值為100%則完全轉為灰度圖像,值為0%圖像無變化。值在0%到100%之間,則是效果的線性乘子。若未設置,值默認是0;|
| hue-rotate(*deg*) | 給圖像應用色相旋轉。"angle"一值設定圖像會被調整的色環角度值。值為0deg,則圖像無變化。若值未設置,默認值是0deg。該值雖然沒有最大值,超過360deg的值相當于又繞一圈。|
| invert(*%*) | 反轉輸入圖像。值定義轉換的比例。100%的價值是完全反轉。值為0%則圖像無變化。值在0%和100%之間,則是效果的線性乘子。 若值未設置,值默認是0。|
| opacity(*%*) | 轉化圖像的透明程度。值定義轉換的比例。值為0%則是完全透明,值為100%則圖像無變化。值在0%和100%之間,則是效果的線性乘子,也相當于圖像樣本乘以數量。 若值未設置,值默認是1。該函數與已有的opacity屬性很相似,不同之處在于通過filter,一些瀏覽器為了提升性能會提供硬件加速。 |
| saturate(*%*) | 轉換圖像飽和度。值定義轉換的比例。值為0%則是完全不飽和,值為100%則圖像無變化。其他值,則是效果的線性乘子。超過100%的值是允許的,則有更高的飽和度。 若值未設置,值默認是1。|
| sepia(*%*) | 將圖像轉換為深褐色。值定義轉換的比例。值為100%則完全是深褐色的,值為0%圖像無變化。值在0%到100%之間,則是效果的線性乘子。若未設置,值默認是0; |
| url() | URL函數接受一個XML文件,該文件設置了 一個SVG濾鏡,且可以包含一個錨點來指定一個具體的濾鏡元素。例如:filter: url(svg-url#element-id)|
| initial | 設置屬性為默認值,可參閱:[CSS initial 關鍵字](https://www.w3cschool.cn/cssref/css-initial.html) |
| inherit | 從父元素繼承該屬性,可參閱:[CSS inherit 關鍵字](https://www.w3cschool.cn/cssref/css-inherit.html) |
* * *
## 實例1--圖片使用高斯模糊效果:
```
<!DOCTYPE html>
<html>
<head>
<style>
img {
-webkit-filter: blur(5px); /* Chrome, Safari, Opera */
filter: blur(5px);
}
</style>
</head>
<body>
<p>圖片使用高斯模糊效果:</p>
<img src="pineapple.jpg" alt="Pineapple" width="300" height="300">
<p><strong>注意:</strong> Internet Explorer 不支持 filter 屬性。</p>
</body>
</html>
```
- CSS常用樣式控制
- background--背景
- Text--文本
- CSS屬性
- align-*
- animation-*
- appearance
- backface-visibility
- background
- background-attachment
- background-blend-mode
- background-clip
- background-color
- background-image
- background-origin
- background-position
- background-repeat
- background-size
- border
- border-bottom
- border-bottom-color
- border-bottom-left-radius
- border-bottom-right-radius
- border-bottom-style
- border-bottom-width
- border-collapse
- border-color
- border-image
- border-image-outset
- border-image-repeat
- border-image-source
- border-image-width
- Border-left
- border-left-color
- border-left-style
- border-left-width
- border-image-slice
- border-radius
- border-right
- border-right-color
- border-right-style
- border-right-width
- border-spacing
- border-style
- border-top
- border-top-color
- border-top-left-radius
- border-top-right-radius
- border-top-style
- border-top-width
- border-width
- bottom
- box-shadow
- box-sizing
- caption-side
- clear
- clip
- color
- column-count
- column-gap
- column-rule
- column-rule-color
- column-rule-style
- column-rule-width
- column-span
- column-width
- columns
- content
- counter-increment
- counter-reset
- cursor
- direction
- display
- Empty-cells
- filter(濾鏡)
- CSS 偽元素選擇器
- :active 選擇器
- :after 選擇器
- :before 選擇器
- :checked 選擇器
- :disabled 選擇器
- :empty 選擇器
- :enabled 選擇器
- :first-child 偽元素
- :first-letter 偽元素
- :first-line 偽元素
- :first-of-type 選擇器
- :focus 選擇器
- :hover 選擇器