CSS中的text-shadow。

text-shadow(文字投影),box-shadow(容器投影),border-radius(圆角)这三个属性估计以后用的比较多,记录 一下。目前不支持IE系列(不过可以使用其他方法实现,下文有详细介绍),无语的IE系,只支持Firefox和chrome。

 

 一、除IE之外的text-shadow

Text Shadow 文本的阴影,给文本添加阴影效果

文字阴影的结构顺序为:x 轴偏移,y 轴偏移,模糊,颜色。

设置一个负值的 x 轴偏移将阴影转移到左侧。设置一个负值的 y 轴偏移转将阴影转移到顶部。别忘了,你可以在阴影颜色中应用 RGBA 值。

书写格式:text-shadow:apx bpx cpx #color

  其中a指X轴上的位移,b指Y轴上的位移,c指阴影的宽度,color指阴影的颜色值;ab可为负,c不能为负。

下面我们来简单的演示两个实例说明text-shadow的用法:

实例一(一种阴影)

    .demo01{text-shadow:2px 2px 5px #305999}

实例二(多种阴影)

    .demo02{background:#305999;text-shadow:1px 1px 1px #fff,-1px -1px 1px #fff}

text-shadow效果:

  效果是不错,可是让我们头痛的是IE是不支持text-shadow效果,但为了在兼容这一问题,我们只好使用滤镜filter:shadow来处 理(本人不提倡使用滤镜)。filter:shadow滤镜作用与dropshadow类似,也能使用对象产生阴影效果,不同的是shadow可产生渐近 效果,使用阴影更平滑实现。

  滤镜语法:

    E {filter:shadow(Color=颜色值,Direction=数值,Strength=数值)}

   其中E是元素选择器,Color用于设定对象的阴影色;Direction用于设定投影的主向,取值为0即零度(表示向上方向),45为右 上,90为右,135为右下,180为下方,225为左下方,270为左方,315为左上方;Strength就是强度,类似于text-shadow中 的blur值。

   我们先不管IE下的效果了,我个人认为text-shadow运用好了,也能像photoshop一样制作出非常好的效果,下面我这里罗列出一些比较好看的实例以供大家参考

  注:下面所有的Demo需要加上这个公用的样式:

    .demo {
      background: #666666;
      width: 440px;
      padding: 30px;
      font: bold 55px "微软雅黑", "Lucida Grande", "Lucida Sans", Helvetica, Arial, Sans;;
      color: #fff;
      text-transform: uppercase;
    }

 

 

  效果一:Glow and Extra Glow effect(也就是NEON effect)

    .demo2 {
      text-shadow: 0 0 20px red;
    }

 

  

 

  辉光效果,我们设置比较大的模糊半径来增加其辉光效果,你可以改变不同的模糊半径值来达到不同的效果,当然你也可以同时增加几个不同的半径值,创造多种不同的阴影效果。就如下面的NEON效果。

    .demo3 {
      text-shadow: 0 0 5px #fff, 0 0 10px #fff, 0 0 15px #fff, 0 0 40px #ff00de, 0 0 70px #ff00de;
    }

 

 

  

 

  效果二:Apple Style Effect

    .demo4 {
      color: #000;
      text-shadow: 0 1px 1px #fff;
    }

 

 

  

 

  效果三:Photoshop Emboss Effect

    .demo5 {
      color: #ccc;
      text-shadow: -1px -1px 0 #fff,1px 1px 0 #333,1px 1px 0 #444;
    }

 

 

  

 

  效果二和效果三,我想用photoshop的朋友一定很熟悉,是不是很类似我们 photoshop中的投影和浮雕效果的呀。应用这两个效果大家一定要注意,其模糊值一定要设置为0,使文本不具有任何模糊效果,主要用来增加其质感,你 也可以像photoshop中制作一样,改变不同的投光角度,从而制作出不同的效果,这里我就不举例子了,感兴趣的朋友可以自己尝试一下。

 

  效果四:Blurytext Effect

    .demo6 {
      color: transparent;
      text-shadow: 0 0 5px #f96;
    }

 

 

  

 

  用text-shadow制作模糊的效果主要要注意一点就是,把文本的前景色设置为透明transparent,如果模糊值越大,其效果越糊 糊;其二,我们不设置任何方向的偏移值。如果结合前面的photoshop emboss效果,可以让你等到不同的效果。提醒一下opera浏览器不支持这个效果。

 

  我们结合前面的Photoshop Emboss效果,我们可以制作出一个带有模糊的浮雕效果:

    .demo7 {
      color: transparent;
      text-shadow:0 0 6px #F96, -1px -1px #FFF, 1px -1px #444;
    }

 

  

 

  效果五:Inset text effect

    .demo8 {
      color: #566F89;
      background: #C5DFF8;
      text-shadow: 1px 1px 0 #E4F1FF;
    }

 

 

  

 

  这种效果需要注意以:文字的前景色要比背景色暗,阴影颜色稍比背景色亮一点点,这一步很重要,如果阴影色太亮看起来会怪,如果太暗将没有效果显示。具体实现可能看看stylizedweb的制作。Inset效果是文本的影子效果,也是常见的一种效果,阴影是同一个小偏移量给人一种微妙的突出效果。

 

  效果六:Stroke text effect

     .demo9 {
      color: #fff;
      text-shadow: 1px 1px 0 #f96,-1px -1px 0 #f96;
     }

 

 

  

 

  描边效果跟我们在Photoshop相比,我承认效果差很多,出现断点,但有时还是可以试用达到一种特殊的描边效果,其主要运用两个阴影,第一个向左上投影,而第二向右下投影,还需注意,制作描边的阴影效果我们不使用模糊值。

 

  效果七:3D text effect

    .demo10 {
      color: #fff;
      text-shadow: 1px 1px rgba(197, 223, 248,0.8),2px 2px rgba(197, 223, 248,0.8),3px 3px rgba(197, 223, 248,0.8),

        4px 4px rgba(197, 223, 248,0.8),5px 5px rgba(197, 223, 248,0.8),6px 6px rgba(197, 223, 248,0.8);
    }

 

 

  

 

  我们换过投影方向可以制作出另外一种3D文字效果:

    .demo11 {
      color: #fff;
      text-shadow: -1px -1px rgba(197, 223, 248,0.8),-2px -2px rgba(197, 223, 248,0.8),-3px -3px rgba(197, 223, 248,0.8),

        -4px -4px rgba(197, 223, 248,0.8),-5px -5px rgba(197, 223, 248,0.8),-6px -6px rgba(197, 223, 248,0.8);
    }

 

 

  

 

  3D文字效果运用原理就是像Photoshop一样,我们在文字的下方或上方复制了多个图层,并把每一个层向左上或右下方向移动一个1px距 离,从而制作出3D效果。同时我们层数越多,其越厚重。换成用text-shadow制作就是使用多个阴影,并把阴影色设置相同,给其使用rgba色效果 更佳,如上面的实例。

 

  效果八:Vintge/Retro text effect:

    .demo11 {
      color: #eee;
      text-shadow: 5px 5px 0 #666, 7px 7px 0 #eee;
    }

 

 

  

 

  Vintage retro这种风格的文字效果是由两个文本阴影合成的,这里需要注意的是:第一个阴影色和背景色相同;文本前景色和第二个阴影色相同

 

  效果九:Anaglyphic text effect

    .demo13 {
      color: rgba(255, 179, 140,0.5);
      text-shadow: 3px 3px 0 rgba(180,255,0,0.5);
    }

 

 

  

 

  anaglyphic文字效果起到一种补色的效果,从而制作出一种三维效果图。其效果是用css重新使用的文字阴影和文本前景的rgba色组合而成。在文本的前景色和阴影上同时使用rgba色,使底层的文字是通过影子可见。

   上面我主要列出了九个不同效果的实例,当然大家可以改变各种方式制作出一些特殊的效果,也再一次证实CSS3中的text-shadow实力是不浅的,希望大家能喜欢上这个属性,并能更好的使用这个属性。虽然现在IE不支持,但大家不要惧怕使用CSS3,因为我们做前端的迟早都会需要掌握这些新技术的。

 

 

  二、IE下如何实现text-shadow

1、glow滤镜下的文字阴影效果
IE滤镜中有个名叫glow的滤镜,用来实现光晕效果,于是,我们可以用来实现无方向的文字阴影效果。
该滤镜最简单的使用类似下面:
filter:glow(color=black,strength=5);
上面实现的效果就是5像素扩散大小的黑色光晕,效果类似下面(截自IE浏览器):

HTML代码:

    <div class="bg">
      <h1 class="font">空谷寻香觅幽兰</h1>
    </div>

css代码:

  .bg {
     width: 512px;
       height: 140px;
      margin: 1em auto;
    background: rgba(255, 123, 189, 0.59);
    }

  .font {
    margin: 0;
    padding: 1em;
    color: #fff;
    text-shadow: 0 0 5px rgb(0, 0, 0);
    font-size: 36px;
    font-family: "微软雅黑";
    float: left;
    filter: glow(color=black, strength=5);
}

运行结果简要展示(上为chrome,下为IE)

  

  

 

 

不足:
1. 虽然IE浏览器的glow光晕滤镜可以实现勉强可以称为的文字阴影效果,但是其效果相比原生的text-shadow属性就是玄彬和郭德纲的区别,并且对不同颜色的支持效果大相径庭,可以看到不仅光晕颜色不纯(杂色丛生),且文字边缘也有不和谐的黑色糙边,让人不仅感叹:你能不能再丑一点。

2. 既然是光晕滤镜,就决定了此方法实现的文字阴影效果是无方向性的,就四周均匀扩散性质的。这是该方法一个较大的局限性。

 

2、MotionBlur滤镜下的文字阴影效果

  IE滤镜中有个名叫MotionBlur的滤镜,用术语称呼其为“动感模糊滤镜”。该滤镜使用的示例如下:

  filter:progid:DXImageTransform.Microsoft.MotionBlur(strength=5, direction=145);

    用中文释义就是:145度方向上5像是大小的动感模糊。

HTML代码:

           <div class="bg">
      <h1 class="font">空谷寻香觅幽兰</h1>
   </div>

CSS代码:

        .bg {
    width: 512px;
    height: 140px;
    margin: 1em auto;
    background: rgba(255, 123, 189, 0.59);
    }

  .font {
    margin: 0;
    padding: 1em;
    color: #fff;
    font-size: 36px;
    font-family: "微软雅黑";
    text-shadow: 1px 1px 5px #fff;
    filter: progid:DXImageTransform.Microsoft.MotionBlur(strength=5, direction=145);
    float: left;
    }

 

运行结果简要展示(上为chrome,下为IE)  

     

    

 

不足:
1. MotionBlur滤镜虽然有了方向性,也可以设定大小,但是,其模糊出来的投影颜色却只能是文字本身的颜色。也就是说,单单一个标签,一个滤镜是无法实现类似于文字白色,投影黑色这种效果的。但是,这种先天性的不足也是可以通过某些手段修复的。

2. 此滤镜在应用动感模糊的同时本身也被模糊了,相对于挖自己身上的肉填饱自己饥饿的肚子。这种实现效果显然是会大打折扣的,正所谓人比人,气死人啊。两者的效果差距可以赶上凤姐和志玲姐的差距了。然而,通过某些小手段,我们也可以让MotionBlur滤镜下的文字阴影效果爷变得很赞,这就是下面一节的内容。

 

 

3、MotionBlur滤镜下文字阴影效果进一步优化

效果实现的原理是两端一模一样的文字相互重叠,背后的文字动感模糊,前面的文字就是很纯洁的文字了。

  filter: progid:DXImageTransform.Microsoft.MotionBlur(strength=5, direction=145);

考虑到不同IE浏览器下的兼容性问题,作为阴影效果的文字标签需要使用block水平的标签,且需要在IE6/IE7浏览器下haslayout。另外,这里的文字重叠是借助了absolute绝对定位元素的无高度性和无宽度性实现的

 

HTML代码:

    <div class="bg">
      <h4 class="font"><span class="text">空谷寻香觅幽兰</span><div class="sh">空谷寻香觅幽兰</div></h4>
    </div>

 

CSS代码:   
    .bg {
      width: 512px;
      height: 140px;
      margin: 1em auto;
      background: rgba(255, 123, 189, 0.59);
    }

    .font {
      margin: 0;
      padding: 1em;
      font-size: 36px;
      font-family: "微软雅黑";
    }

    .text {
      color: #fff;
      position: absolute;
      }

    .sh {
      color: #000;
      text-shadow: 1px 1px 5px #000;
      filter: progid:DXImageTransform.Microsoft.MotionBlur(strength=5, direction=145);
      *zoom: 1;
      }

 

 

运行结果简要展示(上为chrome,下为IE): 

    

    

不足:
  
由于要借助于两段不同的文字实现效果,所以,此方法不使用与长篇大论文字处的投影效果实现,像是标题啊,导航啊这些文字不是很多的地方就可以使用使用。

 

4、远离text-shadow和滤镜的文字阴影实现

  这里实现的原理的精髓其实跟上面的其实一致,两段一模一样的文字,重叠显示,不过,投影效果是通过两段文字的错位差实现的,例如通过margin负值让上下的文字出现1像素的偏移。

 

HTML代码:   
    <div class="bg">
      <h4 class="font"><span class="sh">空谷寻香觅幽兰</span>
        <div>空谷寻香觅幽兰</div>
      </h4>
    </div>

 

 

CSS代码:      
    .
bg {
      width: 512px;
      height: 140px;
      margin: 1em auto;
      background: rgba(255, 123, 189, 0.59);
    }

    .font {
      margin: 0;
      padding: 1em;
      font-size: 36px;
      font-family: "微软雅黑";
      float: left;
    }
    .sh {
      margin: -1px 0 0 -1px;
      color: #fff;
      position: absolute;
    }

    

 

运行结果简要展示(上为chrome,下为IE):

    

    

不足:
文字阴影效果的大小有限,且无法很好的实现透明度变化的投影效果。1像素的偏移投影是其最适用的情况。

 

兼容性解决方案:

 

1、text-shadow的各浏览器前缀

(1) Firefox4.0-

-moz-text-shadow: X轴偏移量 Y轴偏移量 阴影模糊半径 阴影颜色;

(2) Safari and Google chrome10.0-

-webkit-text-shadow: X轴偏移量 Y轴偏移量 阴影模糊半径 阴影颜色;

(3) Firefox4.0+ 、 Google chrome 10.0+ 、 Oprea10.5+ and IE9

text-shadow: X轴偏移量 Y轴偏移量 阴影模糊半径 阴影颜色;

2、text-shadow兼容IE6-8

E {filter:shadow(Color=颜色值,Direction=数值,Strength=数值)}

 

 

 


 

转载于:https://www.cnblogs.com/theWayToAce/p/5271482.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值