CSS教程·滤镜

1、概述

  好了,下面我们将进入CSS的最精彩的部分--滤镜,它将把我们带入绚丽多姿的多媒体世界。正是有了滤镜属性,页面才变得更加漂亮。
  CSS的滤镜属性的标识符是filter。为了使您对它有个整体的印象,我们先来看一下它的书写格式:

   filter:filtername(parameters)

  怎么样?是不是很简单,看上去与前面讲的属性定义没什么太大的差别。Filter是滤镜属性选择符。
  也就是说,只要您进行滤镜操作,就必须先定义filter;filtername是滤镜属性名,这里包括alpha、blur、chroma等等多种属性,详细内容请看下表:

  上面filter表达式中括号内的parameters是表示各个滤镜属性的参数,也正是这些参数决定了滤镜将以怎样的效果显示。
  看了上面长长的列表,是不是觉得很困难呀?不要紧,我们接下来一个一个的介绍这些属性在CSS中是怎样实现的(很简单哟^_^)。
  下一节我们将首先学习Alpha透明属性的应用。

2、alpha属性

  alpha是来设置透明度的。先来看一下它的表达格式:

  filter:alpha(opacity=opcity,finishopacity=finishopacity,
  style=style,startX=startX,startY=startY,finishX=finishX,
  finishY=finishY)

  哇,怎么这么长。是啊,不过这些参数都各有其用。
  Opacity代表透明度等级,可选值从0到100,0代表完全透明,100代表完全不透明。 Style参数指定了透明区域的形状特征。其中0代表统一形状;1代表线形;2代表放射状;3代表长方形。
  Finishopacity是一个可选项,用来设置结束时的透明度,从而达到一种渐变效果,它的值也是从0到100。 StartX和StartY代表渐变透明效果的开始坐标,finishX和finishY代表渐变透明效果的结束坐标。
  从上面讲的我们可以看出,如果不设置透渐变效果,那么只需设置opacity这一个参数就可以了。说了这么多,我们来看一个实例吧(见下图):

  实现上面这种效果的代码如下:

  
  
  alpha
  
  
  
  


  


  Beautiful

//*定义字体属性,前景色为红色*//
  

  


  //*导入一张图片*//
  
  

  如果在上面的代码中稍做改动,则将产生另外多种效果。我们只修改img的样式属性,把head中的Img样式属性代码改为如下所示:

  img{position:absolute;top:20;left:40;
  filter:alpha(opacity=0,finishopacity=100,
  style=1,startx=0,starty=85,finishx=150,finishy=85);}

 
//*设置透明渐变效果,起始坐标,终止渐变坐标,并设置透明样式值(style=1)为   线形*//

  这段代码产生的效果如左下图所示,右面的两幅图分别是把Alpha中的Style参数值为2和3后的效果,点击缩略图可放大。

  

      Style=1        Style=2        Style=3

  以上是CSS的Alpha滤镜属性的应用,具体应用还需要您自己找个例子练一练。
  下一节我们将介绍blur(模糊)属性。

3、blur属性

  假如您用手在一幅还没干透的油画上迅速划过,画面就会变得模糊。CSS下的blur属性就会达到这种模糊的效果。
  先来看一下blur属性的表达式:

  filter:blur(add=add,direction,strength=strength)

  我们看到blur属性有三个参数:add、direction、strength。
  Add参数有两个参数值:true和false。意思是指定图片是否被改变成模糊效果。    Direction参数用来设置模糊的方向。模糊效果是按照顺时针方向进行的。其中0度代表垂直向上,每45度一个单位,默认值是向左的270度。角度方向的对应关系见下表:

  Strength参数值只能使用整数来指定,它表有多少像素的宽度将受到模糊影响。默认值是5像素。
  还是看一个例子吧。点击这里看效果 

  看起来是不是有些像万花筒,在这个例子中加入了一些JavaScript的语句,代码如下:

  
   
   blur css
   
   
   
   

     style=“filter:blur(strength=1)”
     onfilterchange=“handlechange(this)”>

   //*导入一幅图片,初始blur属性strength等于1,同时调用onfilterchange函
   数*//

   


   
  

  注:在javascript中blur属性是这样定义的:
    [oBlurfilter=] object.Filters.blur

  这个例子是Blur属性的一个比较复杂的例子,下一节我将向您介绍两个较简单的blur属性效果。

4、Chroma属性

  Chroma属性可以设置一个对象中指定的颜色为透明色,它的表达式如下:

  Filter:Chroma(color=color)

  这个属性的表达式是不是很简单,它只有一个参数。只需把您想要指定透明的颜色用Color参数设置出来就可以了。比如下面这幅图:

  图中显示两种字体,两种颜色,我们现在对“leaves”字体添加chroma属性,使其透明。代码如下:

  
   
   chroma filter
   
   
   
   


   

LEAVES LOVE


   

   
  

  通过上面代码中对chroma的属性设置,使绿色透明。显示效果如下图:

  我们看到绿色的leaves体不见了,实际上它是透明了,在IE下点击它所在的区域,它还是会显示出来(见下图):

  另外,需要注意的是,chroma属性对于图片文件不是很适合。因为很多图片是经过了减色和压缩处理(比如JPG、GIF等格式),所以它们很少有固定的位置可以设置为透明。

  本节我们讲述了chroma属性的应用,下一节将向您介绍Dropshadow属性。

5、DropShadow属性

  DropShadow属性是为了添加对象的阴影效果的。它实现的效果看上去就像使原来的对象离开页面,然后在页面上显示出该对象的投影。看一看它的表达式:

  Filter:DropShadow(Color=color,Offx=Offx,Offy=offy,
            Positive=positive)

  该属性一共有四个参数: Color代表投射阴影的颜色。 Offx和offy分别X方向和Y方向阴影的偏移量。偏移量必须用整数值来设置。如果设置为正整数,代表X轴的右方向和Y轴的向下方向。设置为负整数则相反。
  Positive参数有两个值:True为任何非透明像素建立可见的投影,False为透明的像素部分建立可见的投影。
  同样,我们先来看一个例子(见下图):

  看,图中的文字就像是从页面上飞出来一样,并且留下了一层淡淡的影子。
  实际上在这里应用的就是CSS的DropShadow属性,我们来看一下它的代码:

  
   
   dropshadow
   
   
   
   


   

        font-weight:bold;color:#CC00CC;”>
   //*定义字体名称、大小、粗细、颜色*//
   Love Leaf


  

  
  

  和chroma属性一样,Dropshadow属对图象的支持不好,我指的是JPEG、GIF格式的图象文件。
  不能支持的原因与Chroma一样,因为这种图象的颜色很丰富,很难找到一个投射阴影的位置。

  本节讲述了Dropshadow属性的应用,下一节将向您介绍FlipH、FlipV的属性应用。

6、FlipH、FlipV属性

  Flip是CSS滤镜的翻转属性,FlipH代表水平翻转,FlipV代表垂直翻转。它们的表达式很简单,分别是:

  Filter:FlipH

  Filter:FlipV

  我们先来看一幅图:

  下面我们分别对它实现水平翻转和垂直翻转,并且在片上方的一段文字,也发生翻转。代码如下:

  
   
   flip css
   
  
   
   


   

         font-weight:bold; color:rgb(10,128,156);”>
    Leaf Village


   //*定义字体名称、大小、粗细、颜色*//
  

  


   //*导入一张图片*//
  
  

  代码产生的两个效果分别如下图:

             

        水平翻转                垂直翻转

  翻转的属性应用是不是很简单。下一节我将向您介绍Glow属性。

 7、Glow属性

  当对一个对象使用“Glow”属性后,这个对象的边缘就会产生类似发光的效果。它的表达式如下:

  Filter:Glow(Color=color,Strength=strength)

  Glow属性的参数只有两个:Color是指定发光的颜色,Strength指定发光的强度,参数值从1到255。 让我们先来看一下加上Glow属性的效果图:

  怎么样,是不是有一种燃烧的火焰的感觉。实现种效果的代码如下:

  
   
    filter glow
   
   
   
   

//*leaf类样式*//
   

         font-size:54pt;font-weight:bold;color:#003366;”>
    Leaf Mylove

//*设置字体名称、大小、粗细、颜色*//
   

   
//*weny类样式*//
   

         font-weight:bold;color:#99CC66;”>
    //设置字体名称、大小、粗细、颜色*//
    Weny Good!


   

   
  

  您还可以随意修改颜色值,看看其他的发光效果是怎样的。
  本节主要讲了Glow属性的应用,下一节将向您介绍Gray属性。

8、Gray属性

  Gray属性把一张图片变成灰度图。它的表达式很简单:

  Filter:Gray

  其实这个属性没什么好讲的,只需在您定义的IMG样式中加入一句代码:

  {Filter:Gray}就一切OK了。
  下面两幅图分别代表未加Gray属性和添加了Gray属的效果:

 

转成gray属性后的效果图

  本节讲述的内容比较简单,下一节将向您介绍Invert转化属性。


9、Invert属性

  Invert属性可以把对象的可视化属性全部翻转,包括色彩、饱和度和亮度值。
  它的表达式也很简单:

  Filter:Invert

  我们再来看一下加上Invert属性前后的片效果变化(如下图):

              

        原图                Invert属性效果图
                 

  我们看到Invert属性实际上达到的是一种“底片”的效果。
  自己拿别的图来试试吧。 本节介绍的是Invert属性,下一节将向您介绍Mask属性。

10、Mask属性

  Mask属性为对象建立一个覆盖于表面的膜。它的表达式也很简单:

  Filter:Mask(Color=颜色)

  只有一个Color参数,用来指定使用什么颜色作为掩膜。
  同样,我们来看一下一幅图片在加上mask属性前后的效果(见下图):

原 图

Mask属性效果图

   加上MASK属性的效果就好象是在用有色眼镜物体一样。上面的效果的代码如下:

  
   
    mask filter
   
   
   
   


   

wenyleaf


   

   
  

  其实,您就算在代码中去掉对字体前景色的定义,得到的效果还是一样的。因为有了Mask属性的定义,它遮罩下的字体颜色的设置就已经失去了意义。
  还有一点需要您注意的地方,mask属性对图片文件的支持还是不够,不能达到应该有的效果。
  本节讲解了Mask属性的应用,下一节将向您介绍Shadow(阴影)属性。


11、Shadow属性

  Shadow属性可以在指定的方向建立物体的投影。它的表达式是这样的:

  Filter:Shadow(Color=color,Direction=direction)

  在这里,Shadow有两个参数值:Color参数用来指定投影的颜色;Direction参数用来指定投影的方向。
  这里说的方向与我们在第二节Blur属性中提到的“方向与角度的关系”是一样的。   也许您会问,前面讲到的Dropshadow属性和Shadow属性有什么不同吗?
  光说的话,您恐怕还难以理解,让我们看一看分别利用这两个属性做出来的效果有什么不同(见下图):

 

                Shadow效果        Dropshadow效果

  这样一对比,就可以很明显的看出两者的不同。
  Shadow属性可以在任意角度进行投射阴影,Dropshadow属性实际上是用偏移来定义阴影的。所以,看上去左图的文字和阴影像是一体的,而右图的文字就像脱离了阴影一样。
  本例的代码如下:

  
   
    shadow
   
  
  
  

//*区域内为Shadow类*//
  

        font-weight:bold;color:#FF9900;”>
    Hongen Online

//*定义字体名称、大小、粗细、前景色*//
   

   
//*区域内为Dropshadow类*//
   

         font-weight:bold;color:#FF9900;”>
    Hongen Online

//*定义字体样式与Shadow类的一样*//
   

   
  

  本节讲述了Shadow属性的应用,下一节将向您介绍Wave(波纹)属性。

12、Wave属性

  Wave属性用来把对象按照垂直的波纹样式打乱。它的表达式如下:

  Filter:Wave(Add=True(False),Freq=频率,LightStrength=增强光效,
      Phase=偏移量,Strength=强度)

  我们看到Wave属性的表达式还是比较复杂的,它一共有五个参数。Add参数有两个参数值:True代表把对象按照波纹样式打乱;False代表不打乱;
  Freq参数指生成波纹的频率,也就是指定在对象上共需要产生多少个完整的波纹。   LightStrength参数是为了使生成的波纹增强光的效果。参数值可以从0到100。    Phase参数用来设置正弦波开始的偏移量。这个值的通用值为0,它的可变范围为从0到100。这个值代表始时的偏移量占波长的百分比。比如该值为25,代表正弦波从90度(360*25%)的方向开始。
  说了一大堆,我们还是先看一个实例吧。比如下面这幅图片:

  下面我们对上面这个页面加上Wave效果,代码如下:

  
   
    wave css
   
   
   
   

//*定义DIV区域内为Wave类*//
   

       font-size=72pt; font-weight:bold;
       color:rgb(189,1,64);”>Leaf


   //*设置字体名称、大小、粗细、颜色*//
   

   

//*导入图片*//    
  
  

  这段代码实现的效果如下图:

  如果把Wave的参数随便做一下改动,就会达到多种效果,请看另外一种效果:(如下图):

  其实这种效果只是增大了freq参数的值,减小了Strength、LightStrength的值就可以了。您也可以多试试,改变其他的参数值,还可以达到许多不同的效果来。
  本节主要讲述了Wave属性的应用,下一节将向您介绍Xray属性。

13、Xray属性

  Xray就是X射线的意思。
  Xray属性,顾名思义,这种属性产生的效果就是使对象看上去有一种X光片的感觉。 它的表达式很简单:

  Filter:Xray

  我们还是先来看一个页面(如下图):

  如果在上面的页面中加入Xray属性,也就是在的