微信小程序 CSS filter(濾鏡)的使用示例

前言

以前在看七月老師的視頻的時候,看到了有一個樣式是-webkit-filter,不知道是什麼(我沒咋學過CSS,嘿嘿,因此不知道是啥),因而查了一下,原來是濾鏡吖。可是在微信小程序裏使用的時候,下面一直飄綠色的波浪線,再仔細查了一下,原來是在Chrome 18, Safari 6,Opera 15中使用 -webkit-filter,還有-moz-filter(適配Firefox),-ms-filter(適配IE 8-9)而微信小程序裏使用的話,使用filter就能夠了。一時間好奇了下,就多試了幾個函數,如下是詳細的筆記css

定義

filter 屬性定義了元素(一般是)的可視效果(例如:模糊與飽和度)。html

分類

  • none 默認值,沒有效果。
  • blur() 高斯模糊
  • brightness() 亮度
  • contrast() 對比度
  • drop-shadow() 陰影
  • grayscale() 灰度
  • hue-rotate() 色相旋轉
  • invert() 反色
  • opacity() 透明度
  • saturate() 飽和度
  • sepia() 復古色
  • url() SVG濾鏡
  • 複合函數 多個濾鏡組合使用

使用

提示:濾鏡一般使用百分比 (如:75%), 固然也可使用小數來表示 (如:0.75)。git

blur

高斯模糊:blur(radius),給圖像設置高斯模糊。"radius"一值設定高斯函數的標準差,或者是屏幕上以多少像素融在一塊兒, 因此值越大越模糊; 若是沒有設定值,則默認是0;這個參數可設置css長度值,但不接受百分比值。github

filter: blur(18px);
複製代碼

image

brightness

亮度:給圖片應用一種線性乘法,使其看起來更亮或更暗。若是值是0%,圖像會全黑。值是100%,則圖像無變化。其餘的值對應線性乘數效果。值超過100%也是能夠的,圖像會比原來更亮。若是沒有設定值,默認是1。web

filter: brightness(70%);
複製代碼

image

contrast

對比度:調整圖像的對比度。值是0%的話,圖像會全黑。值是100%,圖像不變。值能夠超過100%,意味着會運用更低的對比。若沒有設置值,默認是1。小程序

filter: contrast(50%);
複製代碼

image

drop-shadow

給圖像設置一個陰影效果。陰影是合成在圖像下面,能夠有模糊度的,能夠以特定顏色畫出的遮罩圖的偏移版本。 函數接受 (在CSS3背景中定義)類型的值,除了"inset"關鍵字是不容許的。該函數與已有的box-shadow box-shadow屬性很類似;不一樣之處在於,經過濾鏡,一些瀏覽器爲了更好的性能會提供硬件加速。 參數以下: 微信小程序

(必須) 這是設置陰影偏移量的兩個 值. 設定水平方向距離. 負值會使陰影出如今元素左邊. 設定垂直距離.負值會使陰影出如今元素上方。查看可能的單位. 若是兩個值都是0, 則陰影出如今元素正後面 (若是設置了 and/or ,會有模糊效果). (可選) 這是第三個code>值. 值越大,越模糊,則陰影會變得更大更淡.不容許負值 若未設定,默認是0 (則陰影的邊界很銳利). (可選) 這是第四個 值. 正值會使陰影擴張和變大,負值會是陰影縮小.若未設定,默認是0 (陰影會與元素同樣大小). 注意: Webkit, 以及一些其餘瀏覽器 不支持第四個長度,若是加了也不會渲染。瀏覽器

(可選) 查看 該值可能的關鍵字和標記。若未設定,顏色值基於瀏覽器。在Gecko (Firefox), Presto (Opera)和Trident (Internet Explorer)中, 會應用colorcolor屬性的值。另外, 若是顏色值省略,WebKit中陰影是透明的。bash

filter: drop-shadow(15rpx 15rpx 10rpx #999999);
複製代碼

image

grayscale

grayscale(100%)爲黑白色。微信

灰度:將圖像轉換爲灰度圖像。值定義轉換的比例。值爲100%則徹底轉爲灰度圖像,值爲0%圖像無變化。值在0%到100%之間,則是效果的線性乘子。若未設置,值默認是0;

filter: grayscale(60%);
複製代碼

image

hue-rotate

色相:給圖像應用色相旋轉。"angle"一值設定圖像會被調整的色環角度值。值爲0deg,則圖像無變化。若值未設置,默認值是0deg。該值雖然沒有最大值,超過360deg的值至關於又繞一圈。

filter: hue-rotate(90deg);
複製代碼

image

invert

反相:反轉輸入圖像。值定義轉換的比例。100%的價值是徹底反轉。值爲0%則圖像無變化。值在0%和100%之間,則是效果的線性乘子。 若值未設置,值默認是0。

filter: invert(0.8);
複製代碼

image

opacity

透明度:轉化圖像的透明程度。值定義轉換的比例。值爲0%則是徹底透明,值爲100%則圖像無變化。值在0%和100%之間,則是效果的線性乘子,也至關於圖像樣本乘以數量。 若值未設置,值默認是1。該函數與已有的opacity屬性很類似,不一樣之處在於經過filter,一些瀏覽器爲了提高性能會提供硬件加速。

filter: opacity(20%);
複製代碼

image

saturate

飽和度:轉換圖像飽和度。值定義轉換的比例。值爲0%則是徹底不飽和,值爲100%則圖像無變化。其餘值,則是效果的線性乘子。超過100%的值是容許的,則有更高的飽和度。 若值未設置,值默認是1。

filter: saturate(0%);
複製代碼

image

sepia

褐色:復古色 將圖像轉換爲深褐色。值定義轉換的比例。值爲100%則徹底是深褐色的,值爲0%圖像無變化。值在0%到100%之間,則是效果的線性乘子。若未設置,值默認是0;

filter: sepia(70%);
複製代碼

image

url

新建一個文本文件filter.txt,內容以下

<svg xmlns="http://www.w3.org/2000/svg"> 
	<defs> 
		<filter id="filter-primitives"> 
			<feGaussianBlur stdDeviation="3" /> 
			<feColorMatrix type="hueRotate" values="270"/> 
			<feColorMatrix type="saturate" values="0.75"/> 
			<feBlend mode="multiply"/> 
		</filter> 
	</defs> 
</svg>
複製代碼

將文件後綴修改成.svg

在代碼中引用該svg文件

<!--filter:url('svg的路徑#element-id')-->
style="filter:url('../../images/filters.svg#filter-primitives')"
複製代碼

image

複合函數

複合函數中,多個濾鏡使用空格分開。注意: 順序是很是重要的 (例如使用 grayscale() 後再使用 sepia()將產生一個完整的灰度圖片)。

filter: saturate(0%) drop-shadow(15rpx 15rpx 10rpx #999999);
複製代碼

image

具體代碼

demo

相關文章
相關標籤/搜索