1. 程式人生 > 其它 >僅用CSS實現圖片渲染特效 (有學習到了)

僅用CSS實現圖片渲染特效 (有學習到了)

前言

實現圖片高亮效果等特效,就不得不提到CSS3的濾鏡filter屬性,CSS過濾器是一個強大的工具,可以使用它來實現不同的視覺效果(有點像瀏覽器的Photoshop過濾器)。CSS filter屬性提供了在顯示元素之前對元素渲染的模糊或顏色偏移等效果。過濾器通常用於調整影象、背景或邊框的渲染。

瀏覽器支援情況:只有IE瀏覽器不支援filter(濾鏡)屬性,為了相容低版本的safari和google瀏覽器,需要加上字首-webkit- 。

使用語法

filter: none | blur() | brightness() | contrast() | drop-shadow() | grayscale() | hue-rotate() | invert() | opacity() | saturate() | sepia() | url();

標題屬性介紹
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) 給影象設定一個陰影效果。陰影是合成在影象下面,可以有模糊度的,可以以特定顏色畫出的遮罩圖的偏移版本。 函式接受<shadow>(在CSS3背景中定義)型別的值,除了"inset"關鍵字是不允許的。該函式與已有的box-shadow box-shadow屬性很相似;不同之處在於,通過濾鏡,一些瀏覽器為了更好的效能會提供硬體加速。<shadow>引數如下:
<offset-x> <offset-y>(必須)
這是設定陰影偏移量的兩個 <length>值.<offset-x>
設定水平方向距離. 負值會使陰影出現在元素左邊. <offset-y>設定垂直距離.負值會使陰影出現在元素上方。檢視<length>可能的單位.
如果兩個值都是0, 則陰影出現在元素正後面 (如果設定了<blur-radius>and/or<spread-radius>,會有模糊效果).
<blur-radius>(可選)
這是第三個code<length>值. 值越大,越模糊,則陰影會變得更大更淡.不允許負值 若未設定,預設是0 (則陰影的邊界很銳利).
<spread-radius>(可選)
這是第四個<length>值. 正值會使陰影擴張和變大,負值會是陰影縮小.若未設定,預設是0 (陰影會與元素一樣大小).
注意: Webkit, 以及一些其他瀏覽器 不支援第四個長度,如果加了也不會渲染。
<color>(可選)
檢視<color>該值可能的關鍵字和標記。若未設定,顏色值基於瀏覽器。在Gecko (Firefox), Presto (Opera)和Trident (Internet Explorer)中, 會應用colorcolor屬性的值。另外, 如果顏色值省略,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)

CSS 濾鏡可以給同個元素同時定義多個,例如 filter: contrast(150%) brightness(1.5) ,但是濾鏡的先後順序不同產生的效果也是不一樣的;

預設值為: initial

inherit 表示從父級繼承。

注意:濾鏡通常使用百分比 (如:75%), 當然也可以使用小數來表示 (如:0.75)。

程式碼演示

<template>
  <div id="app">
    <img class="animated" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/392/redwood-ukulele-top.jpg" alt="ukulele">
  </div>
</template>
<style>
img {
  display: block;
  max-width: 100vw;
  max-height: 100vh;
}
img.animated {
  animation: filter-animation 5s infinite;
}
@keyframes filter-animation {
  0% {
    filter: sepia(0) saturate(2);
  }

  50% {
    filter: sepia(1) saturate(8);
  }

  100% {
    filter: sepia(0) saturate(2);
  }
}
</style>

演示地址:https://codepen.io/zengguanba...

參考資源

轉發來自這位老哥:https://segmentfault.com/a/1190000040210786

感謝!!!!!!!!!!!!!!!!!!!!!!!!!!!!