css3动画|css3的clip-path属性详细介绍

更新时间:2020-03-30    来源:css3教程    手机版     字体:

【www.bbyears.com--css3教程】

一、温故

关于CSS3 clip-path , 去年圣诞节前前前夕写了篇名为“CSS3/SVG clip-path路径剪裁遮罩属性简介”文章介绍了。不过是简介,很多内容是一笔带过。

CSS3中的 clip-path 可以遮罩很多图形,例如矩形 rectangle , 圆 circle , 椭圆 ellipse , 多边形 polygon , 以及 inset 剪裁。

其中, polygon 多边形构建频频出现了我的视野中,不知是贪图我的美色还是其他什么原因,总之,它成功了,成功引起了我关注。于是,按照虐心剧剧本一贯的尿性,男主和X主发生了很多情感上的纠葛。这里特意呈现给大家,满足大家八卦的天性。

二、成形

clip-path 的前身是SVG, 所以,我们的坐标都是二维的。

polygon 的作用就是根据二维点坐标,依次连线,最后所形成的区域就是我们的遮罩区域了。

 

clip-path之所以没有很普及,是因为其浏览器兼容问题。很多IE浏览器对齐属性不是很支持。我们看下他的浏览器兼容:

 

enter image description here


我们看到IE是完全不支持,尽量使用webkit内核,需要加上内核前缀-webkit-

 

看这个效果,对这个DIV进行了裁剪。

代码如下:


 

.haorooms-small {
    background-size: cover;
    width: 300px;
    height: 300px;
    -webkit-clip-path: polygon(0% 50%, 25% 0%, 75% 0%, 100% 50%, 75% 100%, 25% 100%);
    clip-path: polygon(0% 50%, 25% 0%, 75% 0%, 100% 50%, 75% 100%, 25% 100%);
}
clip-path的inset属性应用


.clip-me { 
  /* 最新规范写法 (没有定位要求), */
  clip-path: inset(10px 20px 30px 40px); /* or "none" */
  /* 值指的是 top, right, bottom, left 四个点 */
}
在clip-path的属性值中的inset()函数中有四个值,分别表达着top/left和bottom/right四个点,圈出一个矩形面积。这个矩形面积外的部分都将被裁剪隐藏掉。

clip-path的其他属性应用

.clip-me {

  /* 引用一个内联的 SVG 路径*/
  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);

  /* inset-rectangle() 将会替代 inset() ? */
  /* rectangle() 有可能出现于 SVG 2 */

  /* 圆角 */
  clip-path: inset(10% 10% 10% 10% round 20%, 20%);

}
SVG 裁剪路径样例:


 
 

本文来源:http://www.bbyears.com/css/90748.html