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

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

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

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

比方说,之前介绍“SVG Sprites技术”时候提到的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" height="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元素, 还可以是circleellipselinepolylinepolygon...等等,甚至是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>

目前Chrome浏览器下的文字剪裁极具马赛克风格,类似下面:

而其他浏览器,例如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矩形剪裁功能及一些应用介绍”一文,不过,需要在positionabsolute后者fixed时候才有作用。

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

据说由于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一文看详解):

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

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

例如,上面.clip-me {} 对应CSS代码应用到图片上,则会是这样子,一个剪裁,一个木有(涂白是为了节约图片大小约37K):

已知,此妹子图片尺寸是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%);
}

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

由于本文是“简介”,故不展开。

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+, Android Browser 4.4+),不仅支持全部的图形解析,还支持内联SVG的url(#foo)解析,但是,外部SVG文件的url()解析还不支持。同时,目前(v42)部分特性需要添加-webkit-私有前缀的,如上面介绍的inset

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

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

.clip-examples {
  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 cubic-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对HTML发展以及整个web发展贡献;在看看现在CSS对SVG发展以及整个web发展的贡献。说不准就会掀起又一个发展浪潮,会迎来体现更佳的诸多web站点。

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

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

以上~

本文为原创文章,会经常更新知识点以及修正一些错误,因此转载请保留原出处,方便溯源,避免陈旧错误知识的误导,同时有更好的阅读体验。
本文地址:http://www.zhangxinxu.com/wordpress/?p=4501

时间: 2024-10-06 21:41:04

CSS3/SVG clip-path路径剪裁遮罩属性简介的相关文章

SVG格式图片转成HTML中SVG的Path路径

AI图标制作完成之后,保存的svg文件包含许多AI的信息,如果要在HTML中使用,我们需要在svg文件中提取/修改信息,重新保存. 1.在AI中已经完成图标,要保存SVG文件,点击"文件(File)"-"另存为(Save As)",在弹出的对话框中保存类型选择SVG(*.svg). 2.svg文件保存后,用文本编辑器打开,找到<path>这一个节点,d属性里面就是这个图片的路径数据[注:在保存svg图标的时候需要使用路径查找器工具将图标制作为复合路径,不

坐标转换成SVG的path路径

function svgPathCurv(a,b,curv) { /* * 弯曲函数. * a:a点的坐标{x:10,y:10} * b:b点的坐标{x:10,y:20} * curv:弯曲程度 取值 -5 到 5 */ curv = curv ? curv : 0; var s, k2, controX, controY, q, l, path = ''; var s = 'M' + a.x + ',' + a.y + ' '; /* * 控制点必须在line的中垂线上 * **求出k2的中垂

SVG剪裁路径和遮罩jQuery幻灯片

SVG剪裁路径和遮罩jQuery幻灯片是一款基于SVG clipPath和mask遮罩元素实现的网站动画幻灯片代码特效. 在线演示本地下载 原文地址:https://www.cnblogs.com/wwhhq/p/8283759.html

通过Inkscape导出字体的path路径并通过snap实现素描动画

本博客中的两个例子我已经放到codepen上了,可以打开链接查看效果和代码: http://codepen.io/fonglezen/pen/gbxGQY http://codepen.io/fonglezen/pen/QwMqZE 第一步: 首先打开inkscape,使用文字工具在画布中输入你想要得到的文字,比如: 第二步: 在菜单栏汇总找到路径菜单,然后在下拉菜单中选择对象转化为路径,首先得选中一个对象哟~ 第三步: 另存为SVG文件,然后使用编辑器打开这个SVG文件,找到文字对应的path

简单聊一聊那些svg的沿路径运动

之前遇见动画就很想用css实现,显然有些效果是我们力所不能及,实现起来麻烦,效果不好,让人捉急.其实归结起来,不同的动画有自己的优势,根据实际情况进行取舍.本文就告诉大家如何用SVG写出个简单动画.就让我们以路径动画为例来说明吧. 类似于下面动画,这种之前就觉得好炫酷 好吧,就算不说这个,没学习之前,svg实现的loading我也不知道怎么搞得. 当然SVG肯定不是只是来做这个的啦,这只是人家神奇的一部分.SVG的优势是 跨设备能力强.体积小.图像可透明,可以与js交互等等等等,在这里不一一介绍

CSS clip:rect矩形剪裁功能及一些应用介绍

CSS clip:rect矩形剪裁功能及一些应用介绍 by zhangxinxu from http://www.zhangxinxu.com 本文地址:http://www.zhangxinxu.com/wordpress/?p=1565 一.长话短说 CSS中有一个属性叫做clip,为修剪,剪裁之意.配合其属性关键字rect可以实现元素 的矩形裁剪效果.此属性安安稳稳地存在于CSS2.1中,且使用上基本上没有类似于max-height/display:table-cell等浏览器 的兼容性问

Binding的Path(路径)

Binding的源可以是控件(一个控件是另一个控件的Source.控件把自己的容器作为Source),把集合作为ItemsControls的Source,把xml作为Tree或者Menu的Source,或者是不给它Source,让他自己去找. 一个控件为另一个控件的Source <TextBox x:Name="textBox" Text="{Binding Value,ElementName=slider1}" BorderBrush="Black

Linux系统下修改环境变量PATH路径的三种方法

比如要把/etc/apache/bin目录添加到PATH中,方法有三: 1.#PATH=$PATH:/etc/apache/bin 使用这种方法,只对当前会话有效,也就是说每当登出或注销系统以后,PATH 设置就会失效 2.#vi /etc/profile 在适当位置添加 PATH=$PATH:/etc/apache/bin (注意:= 即等号两边不能有任何空格) 这种方法最好,除非你手动强制修改PATH的值,否则将不会被改变 3.#vi ~/.bash_profile 修改PATH行,把/et

Linux系统中增加和删除环境变量PATH路径详解

http://blog.csdn.net/pipisorry/article/details/39507699 Linux系统中要把/etc/apache/bin目录添加到PATH中: 1.#PATH=$PATH:/etc/apache/bin 使用这种方法,只对当前会话有效,也就是说每当登出或注销系统以后(关闭terminal就会失效),PATH 设置就会失效 2.#vi /etc/profile 在适当位置添加 PATH=$PATH:/etc/apache/bin (注意:= 即等号两边不能