ホームページ  >  記事  >  ウェブフロントエンド  >  CSS クリップパス

CSS クリップパス

巴扎黑
巴扎黑オリジナル
2017-06-28 10:42:572635ブラウズ

まず最初に、フロントエンド開発は非常に共有精神が強いと思います。私は単なるポーターであり、他の人の優れた記事を主にまとめています。 Da Mo の記事から転載 http://www.w3cplus.com/css3/introducing-css-clip-path-property.html

Web ページでは、主に長方形内に配置されます。一方、印刷メディアはさまざまな形状を持つ傾向があります。この差の原因は、印刷メディアのコンテンツを実現するための適切なツールが欠如していることです。このため、多くのデザイナーは創造性を発揮することになりますが、フロントエンドの実装には莫大な開発コストがかかります。

CSS Shapes Module Level 1 (CSS Shape Module Standard 1) の仕様が登場しましたが、長方形デザインの制限は破られる可能性があります。ただし、不規則なグラフィックもまだ必要です。以前は、不規則なグラフィックスを実装するには、CSS などの他の要素関数を使用してグラフィックスを描画する必要がありましたが、多くの場合、疑似要素や複​​数の要素に依存していました。その結果、CSS シェイプは依然としてその強力な機能を発揮できず、Web は従来の長方形のレイアウトを破壊することになります。幸いなことに、CSS clip-path が表示されます。これは、多くの特別なグラフィック (不規則なグラフィック) を描画するのに役立ちます。アドレスは http://bennettfeely.com/clippy/ です。例: clip-path出现,它可以帮助我们绘制很多特殊的图形(不规则的图形),地址是  http://bennettfeely.com/clippy/   比如:

那么这篇文章,我们就一起来了解这个属性。

学习这个属性之前我们先了解一下兼容性

浏览器兼容性

看到这里,大家肯定会问,浏览器兼容性如何?

IE 和 Edge 不支持这个属性。Firefox 仅部分支持 clip-path (它只支持 url() 语法)。但是 47 以上的版本,激活 Firefox 的layout.css.clip-path-shapes.enabled选项就可以支持这个属性了。

Chrome、Safari 和 Opera 需要使用 -webkit- 前缀支持此属性。不幸的是,它们还不支持外部的 SVG 形状。更多浏览器支持性信息如下:

基本概念

clip-path从单词"clip path"的直译上来说,表示的就是裁剪路径。既然有裁剪,咱们就来了解这里面的几个简单的概念。

裁剪就是从某样东西剪切一块。比如说,我们在<img alt="CSS クリップパス" >元素上,根据需要,剪切一部分需要留下的区域。而在整个裁剪中,将会碰到两个相关的概念:裁剪路径(Clipping Path)裁剪区域(Clipping Region)

裁剪路径是我们用来裁剪元素的路径,它标记了我们需要裁剪的区域。它可以是个简单的形状(比如Web中常见的矩形),也可以是一个复杂的多边形(不规则的多边形)。

裁剪区域是裁剪路径闭合后所包含的全部区域。

 

这样一来,元素分为两部分,裁剪区域和裁剪区域外。浏览器会裁剪掉裁剪区域以外的区域,不仅是背景及其它类似的内容,也包括bordertext-shadow 等。更赞的是,浏览器不会捕获元素裁剪区域以外的 hoverclick 等事件。

 即使如今一些特定元素不受长方形限制,但实际上元素周围的内容还是会认为元素是原始形状(长方形)的,并按此进行文档流的布局。要想使周围元素根据元素裁剪后的形状进行布局,可以使用 shape-outside属性。有关于shape-outside相关详细的介绍,可以阅读有关于CSS Shapes相关的教程,这里不进行过多阐述。

旧的clip

CSS Masking Module Level 1中也提供了一个clip属性。可以说clip是CSS中出现的第一种裁剪技术。其实了解过clip的同学都知道,它就是通过overflow:hidden

🎜それでは、この記事を一緒に終わらせましょう。このプロパティについて学びましょう。 🎜🎜この属性を学ぶ前に、まず互換性について理解しましょう🎜

ブラウザの互換性🎜

🎜ここを参照してください。誰もが必ず尋ねるでしょう。 、ブラウザの互換性はどうですか? 🎜🎜IE と Edge はこの属性をサポートしていません。 Firefox は clip-path 🎜 を部分的にのみサポートします (url() 構文のみをサポートします)。ただし、バージョン 47 以降では、Firefox の layout.css.clip-path-shapes.enabled オプションを有効にすることで、この属性をサポートできます。 🎜🎜Chrome、Safari、Opera🎜 には -webkit-🎜 プレフィックスが必要ですこのプロパティはサポートされています。残念ながら、外部 SVG シェイプはまだサポートされていません。ブラウザのサポート情報の詳細は次のとおりです: 🎜🎜🎜基本概念🎜クリップパス「クリップパス」という単語の直訳では、クリッピングパスを意味します。調整が行われたので、ここでいくつかの簡単な概念を理解しましょう。 🎜🎜カットは、何かから部分を切り取ることです。たとえば、<img alt="CSS クリップパス" > 要素では、必要に応じて残す必要がある領域の一部を切り取ります。トリミング プロセス全体を通じて、クリッピング パスクリッピング領域という 2 つの関連する概念が登場します。 🎜🎜クリッピング パスは要素をトリミングするために使用するパスであり、トリミングする必要がある領域をマークします。単純な形状 (Web で一般的な長方形など) または複雑な多角形 (不規則な多角形) にすることができます。 🎜🎜トリミング領域は、クリッピング パスが閉じられた後に含まれる領域全体です。 🎜🎜 🎜🎜このようにして要素が分割されますトリミング領域とトリミング領域外の 2 つの部分。ブラウザは、背景やその他の同様のコンテンツだけでなく、トリミング領域の外側の領域をトリミングします。border🎜、text-shadow🎜 など。さらに優れているのは、ブラウザが要素のクリッピングの外側の hover🎜、クリック🎜 およびその他のイベント。 🎜🎜 現在、一部の特定の要素は長方形によって制限されていませんが、要素の周囲のコンテンツは実際には要素を元の形状 (長方形) とみなし、それに応じてドキュメント フローをレイアウトします。クリップされた要素の形状に従って周囲の要素のレイアウトを作成するには、shape-outside 属性を使用できます。 shape-outside の詳細については、CSS シェイプに関するチュートリアルを参照してください。ここでは詳しく説明しません。 🎜

古いクリップ

🎜 CSS マスキング モジュール レベル 1 には、clip 属性も提供されます。 clip は CSS に登場した最初のクリッピング技術であると言えます。実際、clip について学習した生徒は、overflow:hidden🎜 を使用して外側の要素を削除していることを知っています。クリッピング領域。言ってみれば、それは本当の作物ではありません。 🎜

clip 属性は、これまでのところ、長方形を切り取る rect()clip属性到目前为止,仅支持rect()函数,就是裁剪出一个矩形(其它形状还无法实现)。


clip: rect(<top>, <right>, <bottom>, <left>);</left></bottom></right></top>

在CSS2.1中,rect()<top></top><bottom></bottom>指定偏移量是从元素盒子顶部边缘算起;<left></left><right></right>指定的偏移量是从元素盒子左边边缘算起。

更为无奈的是,clip属性只能在元素设置了position:absolute或者position:fixed起作用。无法在设置position:relativeposition:static上工作。

在CSS中,clip 属性是已过时的,也就是说它已经不再建议被使用,因为有一个更新的、规范的版本,各个浏览器也将集中努力使用它。

当然,clip也是有一些优势的:因为clip是运行在浏览器中的,它可能会一直有效。而浏览器对它的支持是非常强大的:几乎是有史以来的每一个浏览器。另外,我也听说过了,它作出的动画效果胜过其它的新方法。

但是比起它的优势,clip有两个更为重要的弱点,这也使得它难以被广泛地使用:

  • clip 只对绝对定位的元素有效

  • clip 只能用于矩形,即rect()函数

这真的是非常大的限制!所以来让我们接着说接下来更为重要的属性clip-path

 如果你是第一次接触过clip属性,我建议您花点时间阅读一下这篇文章,它能帮助你对clip有一个简单的了解。

clip-path语法

W3C官方规范提供的clip-path语法:


clip-path: <clip-source> | [ <basic-shape> || <geometry-box> ] | none</geometry-box></basic-shape></clip-source>
其默认值是none。另外简单介绍clip-path几个属性值:
  • clip-source: 可以是内、外部的SVG的<clippath></clippath>元素的URL引用

  • basic-shape: 使用一些基本的形状函数创建的一个形状。主要包括circle()ellipse()inset()polygon()。具体的说明可以看CSS Shapes中有关于说明。另外在CSS Shapes 101一文中也有详细介绍。

  • geometry-box: 是可选参数。此参数和basic-shape函数一起使用时,可以为basic-shape的裁剪工作提供参考盒子。如果geometry-box由自身指定,那么它会使用指定盒子形状作为裁剪的路径,包括任何(由border-radius提供的)的角的形状。

开始使用clip-path

在开始使用clip-path绘制图形,或者说裁剪图形之前,有两点需要大家注意:

  • 使用clip-path要从同一个方向绘制,如果顺时针绘制就一律顺时针,逆时针就一律逆时针,因为polygon 関数のみをサポートしています (その他まだ形は出来ていない)。


    img {
      clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
    }
    🎜 CSS2.1 では、rect()🎜 と <top></top>🎜 および <bottom></bottom> 🎜指定されたオフセットは、要素ボックスの上端から計算されます。<left></left>🎜 および <right></right>🎜 指定されたオフセットは、要素ボックスの左端から計算されます。 🎜🎜🎜🎜さらに無力なのは、clip🎜 属性は要素 position:absoluteにのみ設定できますコード >🎜 または position:fixed🎜 は機能します。 position:relative🎜 および position:static🎜それに取り組んでください。 🎜🎜 CSS では、 <span style="background-color: #c0c0c0;"><code>clip 🎜 属性は廃止されました。つまり、標準化された更新があるため、使用することは推奨されなくなりました。バージョンを変更し、各ブラウザもその使用に重点を置きます。 🎜🎜もちろん、clip🎜 にはいくつかの利点もあります。 >clip🎜 はブラウザで実行され、常に有効になる可能性があります🎜。そして、これに対するブラウザのサポートは非​​常に強力で、これまでに作られたほぼすべてのブラウザがサポートされています。また、他の新しい手法よりもアニメーション効果が優れているという話も聞きました。 🎜🎜しかし、その利点と比較して、clip🎜にはさらに 2 つの重要な弱点があり、それが広く使用されることを困難にしています :🎜
  • 🎜clip🎜 は絶対配置の場合のみです。要素は次のとおりです。有効な 🎜
  • 🎜clip🎜 は長方形にのみ使用できます。つまり、rect()🎜function🎜
🎜これは実際には非常に大きな制限です。それでは、次に重要なプロパティ clip-path に進みましょう。 🎜
  1 nbsp;html>  2   3   4     <meta>  5     <title>Clip path</title>  6     <style>  7         body {  8             margin: 20px auto;  9             text-align: center; 10             font-family: &#39;Lato&#39;; 11             max-width: 640px; 12         } 13  14         h1 { 15             margin-bottom: 100px; 16             font-size: 1.8em; 17         } 18  19         p { 20             display: inline-block; 21             margin: 50px 0px; 22             width: 250px; 23             height: 250px; 24             border-radius: 200px; 25             filter: grayscale(0.9); 26             cursor: pointer; 27         } 28  29         p:hover { 30             filter: none; 31         } 32  33         p:hover .text { 34             opacity: 1; 35         } 36  37         .text { 38             position: absolute; 39             background: rgba(200, 0, 0, 0.5); 40             padding: 20px 0; 41             top: 90px; 42             width: 250px; 43             opacity: 0; 44             text-align: center; 45             color: white; 46             font-size: 1.4em; 47         } 48  49         .left .text { 50             background: rgba(0, 0, 200, .5); 51         } 52  53         .right .text { 54             background: rgba(200, 100, 0, 0.5); 55         } 56  57         .bottom .text { 58             background: rgba(0, 200, 0, 0.5); 59         } 60  61         .top { 62             background: url(&#39;http://t.imgbox.com/KXaGvTFB.jpg&#39;); 63             clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%); 64             background-size: contain; 65             position: relative; 66             left: -125px; 67             top: -130px; 68         } 69  70         .left { 71             background: url(&#39;http://t.imgbox.com/LHPFYSYE.jpg&#39;); 72             clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%); 73             background-size: contain; 74             position: relative; 75         } 76  77         .right { 78             background: url(&#39;http://t.imgbox.com/tlgvPjwn.jpg&#39;); 79             clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%); 80             background-size: contain; 81             position: relative; 82             top: -352px; 83             left: 256px; 84         } 85  86         .bottom { 87             background: url(&#39;http://t.imgbox.com/R7h6VtZr.jpg&#39;); 88             clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%); 89             background-size: contain; 90             position: relative; 91             top: -220px; 92             left: -126px; 93         } 94     </style> 95  96  97 <h1>Images clipped with <code>clip-path</code> Property</h1> 98 <p></p><p>SPORTS</p> 99 <p></p><p>TECHNOLOGY</p>100 <p></p><p>FOOD</p>101 <p></p><p>NATURE</p>102 103 

クリップパス構文

🎜クリップパスは W3C 公式仕様によって提供されます🎜構文: 🎜


🎜

.clip-me {
    clip-path: polygon(10% 20%, 20% 30%, 50% 80%) margin-box;
    margin: 10%;
}
rrree
  • 🎜クリップソース🎜: SVG <clippath></clippath>🎜 要素🎜 /li の URL 参照にすることができます。 >
  • 🎜basic-shape🎜: いくつかの基本的な形状関数を使用して作成された形状。主に circle()🎜、ellipse() が含まれますcode>🎜、<span style="background-color: #c0c0c0;"><code>inset()🎜、および polygon() 🎜。具体的な手順については、「CSS Shapes」の手順を参照してください。 CSS Shapes 101 という記事でも詳しく紹介されています。 🎜
  • 🎜geometry-box🎜: はオプションのパラメータです。このパラメータを basic-shape🎜 関数で使用する場合、 Basic-shape🎜 は、トリミング作業のための参照ボックスを提供します。 geometry-box🎜 が単独で指定されている場合、(border -radius によって提供される角度の形状)。 🎜

クリップパスの使用を開始する

🎜クリップパスの使用を開始する🎜 前グラフィックを描画する場合、またはグラフィックをトリミングする場合は、次の 2 つの点に注意する必要があります: 🎜
  • 🎜 を使用するclip-path🎜 は同じ方向から描画する必要があります。時計回りに描画すると常に時計回りになり、反時計回りに描画すると常に時計回りになります。 polygon🎜 は連続した線分であるため、線分が互いに交差する場合、トリミング領域は常に反時計回りになります。もちろん、特にそのような効果が必要な場合は除きます。 🎜
  • 如果绘制时采用比例的方式绘制,长宽就必须要先行设定,不然有可能绘制出来的长宽和我们想像的就会有差距,使用像素绘制就不会有这样的现象。

先来看一个使用<span style="background-color: #c0c0c0;">polygon</span>()函数绘制的示例:


img {
  clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
}

这段代码会将所有的图片裁剪为菱形。但是为什么图片会被裁剪为菱形而不是梯形或平行四边形之类的呢?这主要取决于函数顶点的值。下图将说明一切:

 

 

每个点的第一个坐标值决定了它在 x 轴上的位置,第二个坐标值指定了它在 y 轴的位置,所有点是顺时针绘制的。比如菱形最右边的点,它位于 y 轴下方一半处,所以它的 y 坐标是 50%。同时这个点位于 x 轴的最右侧,所以它的 x 坐标是 100%。其它点的坐标同理可得。

最后效果如下所示:


  1 nbsp;html>  2   3   4     <meta>  5     <title>Clip path</title>  6     <style>  7         body {  8             margin: 20px auto;  9             text-align: center; 10             font-family: &#39;Lato&#39;; 11             max-width: 640px; 12         } 13  14         h1 { 15             margin-bottom: 100px; 16             font-size: 1.8em; 17         } 18  19         p { 20             display: inline-block; 21             margin: 50px 0px; 22             width: 250px; 23             height: 250px; 24             border-radius: 200px; 25             filter: grayscale(0.9); 26             cursor: pointer; 27         } 28  29         p:hover { 30             filter: none; 31         } 32  33         p:hover .text { 34             opacity: 1; 35         } 36  37         .text { 38             position: absolute; 39             background: rgba(200, 0, 0, 0.5); 40             padding: 20px 0; 41             top: 90px; 42             width: 250px; 43             opacity: 0; 44             text-align: center; 45             color: white; 46             font-size: 1.4em; 47         } 48  49         .left .text { 50             background: rgba(0, 0, 200, .5); 51         } 52  53         .right .text { 54             background: rgba(200, 100, 0, 0.5); 55         } 56  57         .bottom .text { 58             background: rgba(0, 200, 0, 0.5); 59         } 60  61         .top { 62             background: url(&#39;http://t.imgbox.com/KXaGvTFB.jpg&#39;); 63             clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%); 64             background-size: contain; 65             position: relative; 66             left: -125px; 67             top: -130px; 68         } 69  70         .left { 71             background: url(&#39;http://t.imgbox.com/LHPFYSYE.jpg&#39;); 72             clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%); 73             background-size: contain; 74             position: relative; 75         } 76  77         .right { 78             background: url(&#39;http://t.imgbox.com/tlgvPjwn.jpg&#39;); 79             clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%); 80             background-size: contain; 81             position: relative; 82             top: -352px; 83             left: 256px; 84         } 85  86         .bottom { 87             background: url(&#39;http://t.imgbox.com/R7h6VtZr.jpg&#39;); 88             clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%); 89             background-size: contain; 90             position: relative; 91             top: -220px; 92             left: -126px; 93         } 94     </style> 95  96  97 <h1>Images clipped with <code>clip-path</code> Property</h1> 98 <p></p><p>SPORTS</p> 99 <p></p><p>TECHNOLOGY</p>100 <p></p><p>FOOD</p>101 <p></p><p>NATURE</p>102 103 

View Code

效果图如下:

 

 

记得以前CSS绘制图形总得束手束脚,而且还得想法设法,使用clip-path绘制什么六边形、八边形、五角形、心形等,都不再是难事了。OXXO.STUDIO有一篇文章《運用 clip-path 的純 CSS 形狀變換》详细介绍了这些图形是如何绘制的。当然除此之外,在线的CSS clip-path maker提供了很多不规则的图形案例:

利用 geometry-box 裁剪元素

在具体使用geometry-box来裁剪元素之前,对geometry-box做一下相关的了解。

geometry-box可以是CSS クリップパスfillstroke或者view-box。其中CSS クリップパス应用于HTML元素,它具有四种值:margin-boxborder-boxpadding-boxcontent-box

CSS クリップパス

来看个简单的示例:

 


.clip-me {
    clip-path: polygon(10% 20%, 20% 30%, 50% 80%) margin-box;
    margin: 10%;
}

View Code

在上例中,元素的 margin-box 会作为参考,来决定裁剪点的实际位置。点(10%,10%)是 margin-box 的左上角,所以clip-path 的定位会根据此点进行计算。

其实CSS クリップパス和CSS Shapes中的引用框概念非常类似,有关于这方面的介绍,可以花点时间阅读《理解CSS Shapes的引用框》一文。

如果geometry-boxbasic-shape一起使用,可以引用basic-shape提供的引用框。其作用和shape-outside属性类似,更多的细节可以看看shape-outside的属性介绍。

如果geometry-box由自身指定,那么它会使用指定盒子形状作为裁剪的路径,包括任何(由border-radius提供的)的角的形状。

除了CSS クリップパス值,还可以运用SVG元素上,它具有另外三个值:fillstrokeview-box

clipPath 和clip-path

在SVG中有一个clipPath元素。clipPath

>元素不会直接在页面上呈现,他唯一的作用就是可以通过clip-path来引用。它和CSS的clip-path还是有很大的区别。有关于两者的详细介绍可以阅读《CSS和SVG中的剪切:clip-path属性和<clippath></clippath>元素》一文。

而很多时候两者可以结合一起使用。

你不需要在CSS中定义clip-path的值,因为它能够引用SVG中定义的 clipPath

>标签元素。下面是它的使用示例:

HTML


 1 <img  alt="CSS クリップパス" > 2  3 <svg> 4   <defs> 5     <clippath> 6       <circle></circle> 7       <circle></circle> 8     </clippath> 9   </defs>10 </svg>

View Code

CSS


.clip-svg {
    clip-path: url(#myClip);
}

View Code

效果如下图

clip-path和masking

剪裁和遮罩都是用来隐藏元素的一些部分、显示其他部分的。当然了,这两者还是有区别的。区别主要在于这几方面:他们能做的东西,不同的语法,涉及到的不同技术,是新的还是旧的,以及浏览器支持的差异。

两者最主要的区别:遮罩使用的是图像,剪裁使用的是路径

想象一张从左到右、从黑到白渐变的正方形图像,它可以是一个遮罩。对于应用了这个渐变遮罩图像的元素,它在遮罩图像的黑色部分是透明(透视)的,而在遮罩图像的白色的部分是不透明(正常)的。所以作出的结论是:这个元素是从左到右淡入的。

而剪裁一直都是矢量路径的。路径之外的部分是透明的,路径里边的部分是不透明的。

个人觉得有点混乱。因为很多时候可能会碰到某个关于遮罩的教程用的是一个在黑色上有白色矢量形状的遮罩图像,这和剪裁基本是同一个原理。但这还好,它只是混淆了一点东西。

有关于两者相关的详细介绍可以点击这里阅读。

clip-path和CSS Shapes

前面已经多次提到CSS Shapes了,是的,因为CSS Shapes可以帮助我们打破常规则的Web排版,让Web页面可以像媒体杂志一样布局,这将是激动人心的一件事情。

而在CSS Shapes中同样会有clip-path的身影。

clip-path接收与basic-shape相同的形状函数和值(前面提到过)。如果我们定义相同的多边形形状,同时用于shape-outsideclip-path属性上,它将裁掉图像上你定义的形状之外的图像。

 


1 img.right {2     float: right;3     height: 100vh;4     width: calc(100vh + 100vh/4);5     shape-outside: polygon(40% 0, 100% 0, 100% 100%, 40% 100%, 45% 60%, 45% 40%);6     /* clip the image to the defined shape */7     clip-path: polygon(40% 0, 100% 0, 100% 100%, 40% 100%, 45% 60%, 45% 40%);8 }

View Code

结果如下:

下面有个示例

HTML


 1 <p> 2   </p><p> 3   </p> 4   <h1>Cupcakes Recipe</h1> 5   <p> 6     Cupcake ipsum dolor sit. Amet sweet roll sweet roll cheesecake sweet roll apple pie ice cream. Toffee soufflé danish soufflé I love I love dessert I love. Lollipop carrot cake marshmallow I love caramels. Chocolate cotton candy unerdwear.com dessert gingerbread gummies I love. Bonbon chupa chups biscuit danish apple pie. Bonbon muffin dessert wafer chocolate cake sesame snaps candy canes marzipan. 7   </p> 8   <h3>Ingredients</h3> 9   
    10     
  • 1/2 Lorem Ipsum
  • 11     
  • 5g Sugar Ipsum
  • 12     
  • 2 eggs
  • 13   
14   

15     Dessert oat cake candy lollipop topping cotton candy jelly beans I love cake. Brownie sugar plum cotton candy wafer dragée pudding I love. I love I love chocolate. Topping danish carrot cake soufflé liquorice icing gummi bears liquorice dessert. Jujubes oat cake tootsie roll tart.  16   

17   

18     Cookie lollipop cookie gingerbread danish muffin sweet chupa chups. Gingerbread donut muffin biscuit sesame snaps chocolate cake sweet. Sugar plum lemon drops pastry tiramisu chocolate gingerbread. I love pudding biscuit soufflé wafer biscuit.19   

20   

21 

View Code

CSS



 1 * { 2   margin: 0; 3   padding: 0; 4   box-sizing: border-box; 5 } 6  7 body { 8   color: #555; 9   font-size: 0.95em;10   background-color: #eee;11   font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;12 }13 14 .container {15   width: 100%;16   max-width: 1200px;17   margin: 20px auto;18   background-color: white;19 }20 21 .element {22   width: 40%;23   height: 600px;24   float: left;25   background-image: url(http://tympanus.net/codrops-playground/assets/images/cssref/properties/clip-path/cupcakes.jpg);26   background-size: cover;27   background-position: -100px 0;28   background-repeat: no-repeat;29   -webkit-clip-path: ellipse(90% 70% at 0% 50%);30   clip-path: ellipse(90% 70% at 0% 50%);31   -webkit-shape-outside: ellipse(90% 70% at 0% 50%);32   shape-outside: ellipse(90% 70% at 0% 50%);33   -webkit-shape-margin: 2em;34   shape-margin: 2em;35 }36 37 p,38 h1,39 h3 {40   padding: 1em 0;41 }42 43 p {44   margin-right: 4em;45 }46 47 ul {48   list-style: circle;49 }

View Code

 

效果图如下

 

 

 

clip-path示例和工具

前面内容简单的提到过了,<span style="background-color: #c0c0c0;">clip-path</span>是一个强大的属性,除了自身能实现一些特殊效果之外,还可以和SVG结合在一起。另外还可以和Masking以及CSS Shapes在一起,做出我们意想不到的效果。那么有关于clip-path相关的案例,网上已经有大把了。除此之外,clip-path还有一些在线的工具,可以直接帮助我们做一些事情。比如Chrome插件CSS Shapes 编辑器、Clip Path生成器和CSS clip-path Maker: Clippy。

最后强列建议大家收藏好下面这篇文章,因为这篇文章整理了18个有关于clip-path的教程、案例和工具:

 

 

参考资料

  • W3C官方规范

  • clip-path(WBP)

  • clip-path(CSS Reference)

  • Introducing the CSS clip-path Property

总结

本文介绍了有关 clip-path 的基本内容,可以帮助你入门。学习使用这个属性并不会花费太多的时间,但是创造性的使用就需要多多练习了。当浏览器广泛支持此属性时,你就可以使用 clip-path制作出酷炫的效果了。

 

以上がCSS クリップパスの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。