好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

html5教程-CSS3/SVG clip-path路径剪裁遮罩属性简介

小宝典致力于为广大程序猿(媛)提供高品质的代码服务,请大家多多光顾小站,小宝典在此谢过。

&nbs p;

一、SVG属性和 CSS 3属性千丝万缕的关系

CSS3新增属性除了我们现在用的比较多的 border-radius , box -s hadow , gra die nt , .. . 之类,还有很 重要 的一个分支: SVG属性家族!

所谓「SVG属性家族」是指原本SVG的标签属性可以直接使用CSS设置。

比方说,之前介绍“SVG sprite s技 术 ”时候提到的 fill 属性,以及之后专门写了篇 文章 “SVG图标颜色文字般继承与填充”讲CSS中使用SVG的 fill 属性实现一些效果。还有很经典的在CSS中使用 stroke -dasharray 以及 stroke-dashoffset 实现“帅气的SVG路径描边动画效果”以及以后会介绍的 mask 属性等!

而本文的 clip-path 也是其中一员,虽然才露尖尖角,相信以后会像路边的野花到处绽放,这里先抢个先机, 简单 介绍一下。

二、SVG中的clip-path

SVG中,有个名叫 <clipPath> 的元素,人如其名,其专门用来定义剪裁路径的。举个简单例子:

<defs ><!-- 定义 -->    <clipPath id="clipPath"> <!-- 定义剪裁路径 -->        <rect x="0" y="0" width="80" h ei ght="80" /> <!-- 路径详细 -->    </clipPath> </defs> 

上面的 <clipPath> 定义了一个 80*80 的矩形剪裁路径。OK,假设现在SVG中有个 圆 ,SVG代码如下:

<circle cx="60" cy="60" r="50" fill=" # 34538b" />

按照我们浅显的认识, 应该 会出现一个填充某种颜色的圆,类似下截图效果:

但是,如果此时该圆同时设置了 clip-path 属性,且值指向的就是上面定义的剪裁路径 #clipPath 呢?

<circle cx="60" cy="60" r="50" fill="#34538b"  clip-path="url(#clipPath)"  />

则,十五的圆被剪裁成了银杏叶:

您可以狠狠地点击这里:SVG clipPath矩形剪裁示意demo

跟 <g> , <symbol> 等元素类似, <clipPath> 元素里面除了 rect 元素, 还可以是 circle , ellipse , line , polyline , polygon , ... 等等 ,甚至是 text 文本。

<svg>     <defs>         <clipPath id="clipPath">             < text  x="10" y="50" style="font- Size:  20px;">一步之遥</text>         </clipPath>     </defs>     <g  style="clip-path: url(#clipPath);" >         <circle cx="60" cy="60" r="50" fill="#34538b" />         <rect x="0" y="0" width="60" height="90" style="fill:#cd0000;"/>     </g> </svg>

目前Ch rom e浏览器下的文字剪裁极具马赛克风格,类似下面:
@H_936_ 126 @

而其他浏览器,例如IE浏览器,则表现 正常 :

您可以狠狠地点击这里:SVG clipPath文本剪裁示意demo

//zxx: 如果被剪裁的是图片,则我们就可以实现文字遮罩图片效果了,点到为止,我就帮到这里了~

上面列举了“矩形剪裁”和“文本剪裁”两个例子,大家有木有发现在应用 clip-path 属性的时候有什么差别?

啊~这位 同学 眼睛 很尖,一眼就看出来,前者直接标签属性;后者则是 style 样式设置( 红色 高亮代码):

clip-path="url(#clipPath)"  style="clip-path: url(#clipPath);"

style 可以设置,也就是意味着,我们可以直接在CSS代码中使用 clip-path 属性!

三、CSS中的clip-path

1. clip-path与clip
CSS本身就有剪裁属性 clip , 具体可参考11年我写的“CSS clip:rect矩形剪裁功能及一些应用介绍”一文, 不过 ,需要在 pos IT ion 为 absolute 后者 fixed 时候才有作用。

那本文主角 clip-path 与 clip 又 是什么 关系呢?

据说由于 clip 是扶不起的阿斗,于是W3弃之, 开始 培养 clip-path 为新一代的代言人。实际上, clip 在可用性隐藏领域是独领风骚的!好吧,既然群众总是迷恋于浮于表面的东西, clip-path 肯定不会像 clip 一样,慢慢变成沾满灰尘的 半 岛铁盒的。

自然, clip-path 要想取代 clip ,第1步就是要实现 clip 应有的功能,方法值有所变化,不是 rect 了,而是 inset . 看下面的代码对比:

.clip-me {      /* 被抛弃的剪裁 */    position: absolute;  /* absolute或fixed定位是必须的 */    clip: rect(30px 200px 200px 20px);  /* 或"auto" */      /* 如今的剪裁 (无需定位属性) */    clip-path: inset(30px 200px 200px 20px);  /* 或"none" */  } 

按照 常识 理解,四个方位值含义应该和传统 clip: rect() 是一模一样滴(参考下图示意,若还不开窍,去CSS clip一文看详解):

但是,但是,注意前方高能!根据我在C hr ome浏览器下的测试(目前为数不多支持 clip-path:inset() 的浏览器)下的测试, clip-path:inset() 4个值的含义与传统 clip: rect() 是不一样的 !

或许是目前的Chrome还不是很规范,但是,至少,当下,两者是有差别的。

例如,上面 .clip-me {} 对应CSS代码应用到图片上,则会是这样子,一个剪裁,一个木有:

已知,此妹子 图片尺寸 是 256 * 191 ,此时,如果我们 clip-path:inset() 如下设置,则结果大不同:

.clip-me {     clip-path: inset(30px 56px 0 20px); }

则是下面这样:

会看到剪裁区域大小都一样了!诶?我们不禁疑问, clip-path:inset() 四个值的玄机在哪里?很简单,虽然四个值代表的方位是一样的,分别是上边缘、 右边 缘、下边缘和左边缘;但是,值大小对应的则是 距离 原始元素的4个边的距离 (传统clip是对应“上/左”2个 边距 离)。加减示意下就是:

 clip: rect(30px 200px 200px 20px) = clip-path: inset(30px (256-200)px (191-200)px 20px) 

您可以狠狠地点击这里:CSS clip-path inset图片剪裁示意demo

作为新时代的宠儿,自然 inset 不能就矩形剪裁这么点花样,例如:

.clip-path {     - webkit -clip-path: inset(10% round 10% 50% 10% 50%);             clip-path: inset(10% round 10% 50% 10% 50%); }

则会让图片剪裁成这样子:

其中 round 关键字表示圆角之意。然后前后个支持最多4个值,和 border-radius 类似,4个值分别对应左上角及顺时针 方向 3个角。前面4个值应该是外圆角,后面4个值应该表示内圆角。

2. clip-path与SVG clip-path
clip-path 除了作为 clip 的替身,还是SVG clip-path 属性的延伸。于是,SVG中玩得比较开心的东西CSS中也同样适用:

.clip-me {     /* 剪裁路径来自内联SVG <clipPath>元素 */    clip-path: url(#c1);      /* 路径来自外部SVG */    clip-path: url(path.svg#c1);     /* 多边形 */    clip-path: polygon(5% 5%, 100% 0%, 100% 75%, 75% 75%, 75% 100%, 50% 75%, 0% 75%);     /* 圆 */    clip-path: circle(30px at 35px 35px);     /* 椭圆 */    clip-path: ellipse(65px 30px at 125px 40px); }

看上去好NB, 但是,兼容性是很糟糕的 现状 。IE浏览器全军覆没。FireFox浏览器目前(v36)仅支持 url() 解析, Chrome浏览器要领先不少(同样有iOS Safari 7.1+, And ROI d br owser 4.4+),不仅支持全部的图形解析,还支持内联SVG的 url(#foo) 解析,但是,外部SVG文件的 url() 解析还不支持。同时,目前(v42)部分特性需要添加 -webkit- 私有前缀的,如上面介绍的 inset 。

同时,基本上, path 元素是无法支持的,主要是语法太复杂,无法在CSS中以 简易 规则书写。

当图形元素变成CSS clip-path 的嫁衣时候,语法会有些变化:

.clip-ex am ples {   clip-path: rectangle(x, y, width, height, rounded-x, rounded-y)     clip-path: inset-rectangle( From  top, from right, from bottom, from left, rounded-x, rounded-y)    /* 应使用inset()替换之~ */    clip-path: polygon(a, bunch, of, points)   clip-path: circle(radius at x, y)   clip-path: ellipse(radius-x, radius-y at x, y) }

clip-path 在CSS语法中游走的时候,也传承了CSS3的一些高级特性,比方说 transition 过渡和 animation 动画,例如下面这个效果:

别小看上面的效果,如果是纯粹的CSS技术,还真实现不了这般效果,因为总会有些位移(不服你可以挑战),只能使用这种剪裁 或者 mask 遮罩实现。

相关CSS代码如下:

.clip-path {     transition: 0.4s c ub ic-bezier(1, -1, 0, 2);     -webkit-clip-path: circle(180px at 128px 95px);     clip-path: circle(180px at 128px 95px); } .clip-path:hover {     -webkit-clip-path: circle(95px at 128px 95px);     clip-path: circle(95px at 128px 95px); }

您可以狠狠地点击这里:CSS clip-path从方形都圆形动画效果示意demo

四、结束语

相关内容很多的,篇幅有限,容不小那么多。旨在展示一些基本应用。当下CSS clip-path 还在快速 发展 之中,但是,有些效果还真得 clip-path 来协助实现,这使得即使现在的兼容情况不佳、还有N多限制与不支持,但仍无法阻挡 clip-path 在个人或内部项目中冉冉升起。

我只想说,潜力巨大。想想 当年 CSS对HT ML 发展以及整个web发展贡献;在看看现在CSS对SVG发展以及整个web发展的贡献。说不准就会掀起又一个发展浪潮,会迎来体现更佳的诸多web站点。

感谢阅读,欢迎纠错,欢迎交流!

本文有少部分内容参考自:

SVG Clip Path Clipping and Masking in CSS

以上~

(本篇完)

觉得 可用,就经常来吧! 欢迎评论哦!  html5教程 ,巧夺天工,精雕玉琢。小宝典献丑了!

总结

以上是 为你收集整理的 html5教程-CSS3/SVG clip-path路径剪裁遮罩属性简介 全部内容,希望文章能够帮你解决 html5教程-CSS3/SVG clip-path路径剪裁遮罩属性简介 所遇到的问题。

如果觉得 网站内容还不错, 推荐好友。

查看更多关于html5教程-CSS3/SVG clip-path路径剪裁遮罩属性简介的详细内容...

  阅读:87次