ホームページ > ウェブフロントエンド > htmlチュートリアル > CSS3 Magic Hall: CSS3 フィルターと Canvas、SVG、IE フィルターの代替品の詳細な説明 [転送]_html/css_WEB-ITnose

CSS3 Magic Hall: CSS3 フィルターと Canvas、SVG、IE フィルターの代替品の詳細な説明 [転送]_html/css_WEB-ITnose

WBOY
リリース: 2016-06-24 11:22:24
オリジナル
1161 人が閲覧しました

1. はじめに

IE 固有のフィルターは、CSS3 のさまざまな新機能のダウングレード処理の補足としてよく使用され、Adobe が HTML5 に移行した後、Chrome と協力して CSS3 のフィルター機能を開始しました。現在、Webkit カーネルのみが参照されます。ブラウザは CSS3 フィルターをサポートしていますが、FF と IE10+ では代替として SVG フィルター (HTML の SVG 効果) または Canvas を使用する必要があります。一方、IE5.5 ~ 9 では IE フィルター、JS+DIV、または VML を使用します。この記事は最初に穴を埋めるためのもので、後で埋めていきます^_^! ! !

CSS3 フィルターの互換性表

HTML の SVG 効果の互換性表

次のフィルターについては以下で説明します。

Speia フィルター グレースケール フィルター ガウスぼかしフィルター 反転カラー フィルター 彩度フィルター

コントラスト フィルター 明るさフィルター 色相回転フィルター シャドウ フィルター

First P Zhang Yuan 画像参照システム (純粋な MM ああ! ! )

2 . Speia フィルター (Speia)

Speia フィルターは、写真や要素全体を古い写真のようにセピア色に加工するために使用されます。効能は下記をご覧ください!

ほら、時間の痕跡、お母さんの時代のような気がしますか? !

1. CSS3フィルター実装

<style type="text/css">  .sepia{    /**  格式,filer: sepia(效果范围)     *  效果范围,取值范围为0-1或0-100%;0表示无效果,1或100%表示最大效果     */    -webkit-filter: sepia(100%);      -moz-filter:sepia(100%);    -o-filter: sepia(100%);    -ms-filter: sepia(100%);    filter: sepia(100%);    }</style><div class="sepia" style="background:url(./mm.jpg)"></div>
ログイン後にコピー

2. IE5.5~9の特殊処理方法(検討中)

IEフィルター filter:progid:XDImageTransform .Microsoft.Maskフィルター(カラー) =color)はgif画像のみ使用可能(他の形式の画像は要素全体が消えてしまいます)、また、IE11ブラウザのドキュメントモードでは、画像とマスクレイヤーが重なった部分が空白になります。フィルタはすべて無効です (要素はフィルタが設定されていないようにレンダリングおよび表示されます)。 結論: IE フィルターはセピア効果を処理できません。

js による穴埋めについては、アイデア 1: 要素の表面に半透明の黄褐色のマスク レイヤーをアタッチしますが、その効果は CSS3 フィルターとは程遠く、失敗します。 。 。 。 。 。 。

3. FFとIE10+の扱い方

Canvasを使って処理することができます。 対象となる要素は

// 定义处理方法var sepia = function(el){  var canvas = document.createElement('canvas');  var w = canvas.width = el.offsetWidth,        h = canvas.height = el.offsetHeight;  var ctx = canvas.getContext('2d');  ctx.drawImage(el, 0, 0);    // 对像素作处理  var imgData = ctx.getImageData(0, 0, w, h), d = imgData.data;  for (int i = 0, len = d.length; i < len; i+=4){    var r = d[i],         g = d[i+1],         b = d[i+2];    d[i] = (r * 0.393)+(g * 0.769)+(b * 0.189);    d[i+1] = (r * 0.349)+(g * 0.686)+(b * 0.168);    d[i+2] = (r * 0.272)+(g * 0.534)+(b * 0.131);  }  ctx.putImageData(imgData, 0, 0);  // 导出  var img = new Image();  img.src = ctx.toDataURL("image/*");  return img;};// 调用var img = sepia(document.getElementById('sepia'));document.body.appendChild(img);
ログイン後にコピー

3. グレースケールフィルター(グレースケール)

グレースケールアートスタイル!

1. CSS3フィルターの実装

<style type="text/css">  .grayscale{    /**  格式,filer: grayscale(效果范围)     *  效果范围,取值范围为0-1或0-100%;0表示无效果,1或100%表示最大效果     */     -webkit-filter: grayscale(100%);     -o-filter: grayscale(100%);     -moz-filter: grayscale(100%);     -ms-filter: grayscale(100%);     filter: grayscale(100%);    }</style><div class="grayscale" style="background:url(./mm.jpg)"></div>
ログイン後にコピー

2. IE5.5~9の実装

IE フィルターを使用します: filter:gray

3 . FFとIE10+の対処法

HTMLでSVG効果を使う方法:

greyscale.svg

:

html:

<svg xmlns="http://www.w3.org/2000/svg">   <filter id="grayscale">    <feColorMatrix type="matrix" values="0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0"/>   </filter>  </svg>  
ログイン後にコピー

キャンバスを使用できます処理

、以下は簡単な実装のコードです。対象要素は です。ガウスぼかしフィルター ミラー(ぼかし)

ガウスぼかしを見ると、街中でメガネを忘れたシーンを思い出します*~*!

1. CSS3フィルターの実装

<style type="text/css">.grayscale{  filter:url(./grayscale.svg#grayscale);}</style><div class="grayscale" style="background:url(./mm.jpg)"></div>
ログイン後にコピー

2 . IE5.5~9の実装

使用IE滤镜: filter: progid:DXImageTransform.Microsoft.Blur(PixelRadius=10, MakeShadow=false); ,该方式在IE11中文档模式为5.5~9均起作用。

3. FF和IE10+的实现

  使用SVG effect for HTML的方式:

   blur.svg:

<?xml version="1.0" encoding="utf-8"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg version="1.1"      xmlns="http://www.w3.org/2000/svg"     xmlns:xlink="http://www.w3.org/1999/xlink"     xmlns:ev="http://www.w3.org/2001/xml-events"          baseProfile="full">         <defs>        <filter id="blur">            <feGaussianBlur stdDeviation="10" />        </filter>    </defs><br />    <image xlink:href="./mm.jpg" x="0" y="0" height="200" width="200" filter="url(#blur)"/></svg>
ログイン後にコピー

index.html(FF下):

<style type="text/css">.blur{  filter: url(blur.svg#blur);}</style><div class="blur" style="background:url(./mm.jpg)"></div>
ログイン後にコピー

index.html(IE10+下,IE10+不支持直接在样式表对元素应用SVG滤镜):

<style type="text/css">.blur{  background-iamge: url(blur.svg);}</style><div class="blur"></div>
ログイン後にコピー

使用Canvas作处理,高斯模糊的算法请参考:阮老师的“高斯模糊的算法”参考译文,处理库StackBlur.js。

处理库API: stackBlurImage( sourceImageID, targetCanvasID, radius, blurAlphaChannel );

  • sourceImageID表示要模糊的图片的 id, 默认这个图片要隐藏;
  • targetCanvasID表示要显示模糊图片的 canvas元素的 id;
  • radius表示模糊的半径大小。不过,根据我的对比测试, radius好像与CSS中filter滤镜的模糊值不是 1:1匹配的,反倒是有些类似 2:1. 也就是这里的 20px的半径模糊近似于CSS中 blur滤镜值设置为 10px;
  • blurAlphaChannel为布尔属性,表示 aplha透明通道是否要模糊, true表示要模糊。
  • 五、反色滤镜(Inver)                        

    经历过胶圈年代的同学都熟悉哦!

    1. CSS3滤镜的实现

    <style type="text/css">  .invert{    /**  格式,filer: invert(效果范围)     *  效果范围,取值范围0~1或0~100%,0为无效果,1或100%表示最大效果     */     -webkit-filter: invert(1);     -moz-filter: invert(1);     -o-filter: invert(1);     -ms-filter: invert(1);     filter: invert(1);   }</style><div class="invert" style="background:url(./mm.jpg)"></div>
    ログイン後にコピー

    2. IE5.5~9的实现(待研究)

    3. FF和IE10+的实现

    可使用Canvas作处理,下面是简单实现的代码,目标元素

    var invert = function(el){  var canvas = document.createElement('canvas');  var w = canvas.width = el.offsetWidth,        h = canvas.height = el.offsetHeight;  var ctx = canvas.getContext('2d');  ctx.drawImage(el, 0, 0);    // 对像素作处理  var imgData = ctx.getImageData(0, 0, w, h), d = imgData.data;  for (int i = 0, len = d.length; i < len; i+=4){    var r = d[i],         g = d[i+1],         b = d[i+2];    d[i] = 255 - r;    d[i+1] = 255 - g;    d[i+2] = 255 - b;  }  ctx.putImageData(imgData, 0, 0);  // 导出  var img = new Image();  img.src = ctx.toDataURL("image/*");  return img;};// 调用var img = invert(document.getElementById('invert'));document.body.appendChild(img);
    ログイン後にコピー

    六、饱和度滤镜(Saturate)                      

    暖暖的赶脚~~~!

    1. CSS3滤镜的实现

    <style type="text/css">  .saturate{    /**  格式,filer: saturate(效果范围)     *  效果范围,取值范围>=0的数字或百分数,1为无效果,0为灰度图     */     -webkit-filter: saturate(2);     -moz-filter: saturate(2);     -o-filter: saturate(2);     -ms-filter: saturate(2);     filter: saturate(2);   }</style><div class="saturate" style="background:url(./mm.jpg)"></div>
    ログイン後にコピー

    2. IE5.5~9的实现(待研究)

    3. FF和IE10+的实现 (待研究)

    七、对比度滤镜(Contrast)                         

    1. CSS3滤镜的实现

    <style type="text/css">  .contrast{    /**  格式,filer: contrast(效果范围)     *  效果范围,取值范围>=0的数字或百分数,1为无效果     */     -webkit-filter: contrast(2);     -moz-filter: contrast(2);     -o-filter: contrast(2);     -ms-filter: contrast(2);     filter: contrast(2);   }</style><div class="contrast" style="background:url(./mm.jpg)"></div>
    ログイン後にコピー

    2. IE5.5~9的实现(待研究)

    3. FF和IE10+的实现 (待研究)

    八、亮度滤镜(Brightness)                      

    曝光过度哦!

    1. CSS3滤镜的实现

    <style type="text/css">  .brightness{    /**  格式,filer: brightness(效果范围)     *  效果范围,取值范围>=0的数字或百分数,1为无效果     */     -webkit-filter: brightness(2);     -moz-filter: brightness(2);     -o-filter: brightness(2);     -ms-filter: brightness(2);     filter: brightness(2);   }</style><div class="brightness" style="background:url(./mm.jpg)"></div>
    ログイン後にコピー

    2. IE5.5~9的实现(待研究)

    3. FF和IE10+的实现

       可使用Canvas作处理,下面是简单实现的代码,目标元素

    // 原理:让图像变得更亮或更暗,算法将红色通道、绿色通道、蓝色通道,同时加上一个正值或负值。var brightness = function(el, delta){  var canvas = document.createElement('canvas');  var w = canvas.width = el.offsetWidth,        h = canvas.height = el.offsetHeight;  var ctx = canvas.getContext('2d');  ctx.drawImage(el, 0, 0);    // 对像素作处理  var imgData = ctx.getImageData(0, 0, w, h), d = imgData.data;  for (int i = 0, len = d.length; i < len; i+=4){    var r = d[i],         g = d[i+1],         b = d[i+2];    d[i] = r + delta;    d[i+1] = g + delta;    d[i+2] = b + delta;  }  ctx.putImageData(imgData, 0, 0);  // 导出  var img = new Image();  img.src = ctx.toDataURL("image/*");  return img;};// 调用var img = brightness(document.getElementById('brightness', 10));document.body.appendChild(img);
    ログイン後にコピー

    九、色相旋转滤镜(Hue Rotate)                        

    诡异的赶脚~~

    1. CSS3滤镜的实现

    <style type="text/css">  .hue-rotate{    /**  格式,filer: hue-rotate(效果范围)     *  效果范围,取值范0deg~365deg,0(默认值)为无效果     */     -webkit-filter: hue-rotate(200deg);     -moz-filter: hue-rotate(200deg);     -o-filter: hue-rotate(200deg);     -ms-filter: hue-rotate(200deg);     filter: hue-rotate(200deg);   }</style><div class="hue-rotate" style="background:url(./mm.jpg)"></div>
    ログイン後にコピー

    2. IE5.5~9的实现(待研究)

    3. FF和IE10+的实现 (待研究)

    十、阴影滤镜(Drop Shadow)                     

    增加立体感!

    1. CSS3滤镜的实现

    <style type="text/css">  .drop-shadow{    /**  格式,filer: drop-shadow(x-offset y-offset 阴影模糊半径 阴影颜色)     *  x-offset和y-offset为阴影的相对于元素左上角的位移距离;     * 注意:     *     1. 阴影的外观受border-radius样式的影响;     *     2. :after和:before等伪元素会继承阴影的效果。     */     -webkit-filter: drop-shadow(5px 5px 0px #333);     -moz-filter: drop-shadow(5px 5px 0px #333);     -o-filter: drop-shadow(5px 5px 0px #333);     -ms-filter: drop-shadow(5px 5px 0px #333);     filter: drop-shadow(5px 5px 0px #333);      // 圆角     border: solid 10px #e00;     -webkit-border-radius: 10px;  }</style><div class="drop-shadow" style="background:url(./mm.jpg)"></div>
    ログイン後にコピー

    2. IE5.5~9的实现

    在真实的IE5.5~9下可使用IE滤镜(IE10+中文档模式为5.5~9则下列的IE滤镜无效):

    /** * color为阴影颜色,形如"#ff00cc" * direction为角度,取值范围0,45,90,135,180,225,270,315 */filter:Shadow(Color=color,Direction=direction);/** * color为阴影颜色,形如"#ff00cc" * offx为水平偏移量 * offy为垂直偏移量 * positive为1或0 */filter:DropShadow(Color=color,OffX=offX,OffY=offY,Positive=positive);
    ログイン後にコピー

     

           IE10+中文档模式为5.5~9时,则需要DIV+JS处理了。其中有一个jQuery插件:http://www.hintzmann.dk/testcenter/js/jquery/boxshadow/jquery.boxshadow.js

     

      3. FF和IE10+的实现 

          通过CSS3新特新Box-Shadow处理, box-shadow: 投影方式(inset) X轴偏移量(x-offset) Y轴偏移量(y-offset) 阴影模糊半径(blur-radius) 阴影扩展半径(spread-radius) 阴影颜色(color) 。

           投影方式(inset) ,可选属性(默认为外阴影),设置为inset时表示内阴影。

           X轴偏移量(x-offset) ,正值表示阴影位于对象的右边,负值表示阴影位于对象的左边。

           Y轴偏移量(y-offset) ,正值表示阴影位于对象的底部,负值表示阴影位于对象的顶部。

           阴影模糊半径(blur-radius) ,可选属性(默认为0,没有模糊效果),值范围>=0。

           阴影扩展半径(spread-radius) ,可选属性,正值表示阴影扩展,负值表示阴影缩小。

           颜色(color) ,可选属性(默认值又浏览器决定, Webkit内核的为透明)。

           注意:

        1. 投影的外观受到border-radius样式的影响;

                2. :after和:before等伪元素不继承投影的效果。

     

    十一、总结                            

        上述内容仅仅对CSS3滤镜和FF、IE下的替代方案作简单的介绍,如有纰漏请各位指正,谢谢!

     

    十二、参考                            

    http://blog.csdn.net/hfahe/article/details/7104496

    http://www.yyjcw.com/html/News/793.html

    http://www.hackbase.com/tech/2014-11-10/69684.html

    http://blog.csdn.net/lujunql/article/details/6260643

    http://www.cnblogs.com/shiyangxt/archive/2008/11/16/1334633.html

    http://www.adobe.com/cn/devnet/html5/articles/css3-basics.html

    http://www.educity.cn/jianzhan/630820.html

    http://www.526net.com/blog/qianduan/226.html

    http://www.zhangxinxu.com/wordpress/2013/11/%E5%B0%8Ftip-%E4%BD%BF%E7%94%A8css%E5%B0%86%E5%9B%BE%E7%89%87%E8%BD%AC%E6%8D%A2%E6%88%90%E6%A8%A1%E7%B3%8A%E6%AF%9B%E7%8E%BB%E7%92%83%E6%95%88%E6%9E%9C/

    SVG

    (applying-svg-effects-to-html-content)——http://robert.ocallahan.org/2008/06/applying-svg-effects-to-html-content_04.html

    Canvas

    http://www.webclks.com/archives/829

    http://www.w3school.com.cn/tags/canvas_getimagedata.asp

    http://www.webhek.com/convert-canvas-image

    如果您觉得本文的内容有趣就扫一下吧!捐赠互勉!
      

     

    分类:  CSS

     

     

    ソース:php.cn
    このウェブサイトの声明
    この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
    人気のチュートリアル
    詳細>
    最新のダウンロード
    詳細>
    ウェブエフェクト
    公式サイト
    サイト素材
    フロントエンドテンプレート