--- title: clip-path slug: Web/CSS/clip-path tags: - CSS - CSS マスク - CSS プロパティ - Experimental - リファレンス - ウェブ - recipe:css-property browser-compat: css.properties.clip-path translation_of: Web/CSS/clip-path --- {{CSSRef}} **`clip-path`** は [CSS](/ja/docs/Web/CSS) のプロパティで、要素のどの部分を表示するかを設定するクリッピング領域を作ります。具体的には、領域の内部の部分は表示され、外側の部分は非表示になります。 {{EmbedInteractiveExample("pages/css/clip-path.html")}} ## 構文 ```css /* キーワード値 */ clip-path: none; /* 値 */ clip-path: url(resources.svg#c1); /* 値 */ clip-path: margin-box; clip-path: border-box; clip-path: padding-box; clip-path: content-box; clip-path: fill-box; clip-path: stroke-box; clip-path: view-box; /* 値 */ clip-path: inset(100px 50px); clip-path: circle(50px at 0 100px); clip-path: ellipse(50px 60px at 0 10% 20%); clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%); clip-path: path('M0.5,1 C0.5,1,0,0.7,0,0.3 A0.25,0.25,1,1,1,0.5,0.3 A0.25,0.25,1,1,1,1,0.3 C1,0.7,0.5,1,0.5,1 Z'); /* ボックスおよびシェイプ値の組み合わせ */ clip-path: padding-box circle(50px at 0 100px); /* グローバル値 */ clip-path: inherit; clip-path: initial; clip-path: revert; clip-path: unset; ``` `clip-path` プロパティは、以下に挙げた値のうちの一つまたは組み合わせで指定します。 ### 値 - `` - : {{cssxref("url()")}} で、[SVG](/ja/docs/Web/SVG) の {{SVGElement("clipPath")}} 要素を参照します。 - {{cssxref("<basic-shape>")}} - : `` 値で寸法と位置が定義されるシェイプです。ジオメトリボックスが指定されない場合、参照ボックスとして `border-box` が使用されます。以下のいずれかです。 - {{cssxref("basic-shape/inset()","inset()")}} - : 内部の長方形を定義します。 - {{cssxref("basic-shape/circle()","circle()")}} - : 半径と中心位置を使用して円を定義します。 - {{cssxref("basic-shape/ellipse()","ellipse()")}} - : 2つの半径と位置を指定して楕円を定義します。 - {{cssxref("basic-shape/polygon()","polygon()")}} - : SVG の塗りつぶし規則と頂点のセットを用いて多角形を定義します。 - {{cssxref("path()","path()")}} - : SVG の塗りつぶし規則と SVG のパス定義を用いて形状を定義します。 - `` - : `` と共に指定された場合、この値は基本シェイプの参照ボックスを定義します。単独で指定された場合、指定のボックスの辺を、角の形 ({{cssxref("border-radius")}} など) を含めてクリッピングパスにします。ジオメトリボックスは以下の値のうちの一つが指定できます。 - `margin-box` - : [マージンボックス](/ja/docs/Web/CSS/CSS_Shapes/From_box_values#margin-box)を参照ボックスとして使用します。 - `border-box` - : [境界ボックス](/ja/docs/Web/CSS/CSS_Shapes/From_box_values#border-box)を参照ボックスとして使用します。 - `padding-box` - : [パディングボックス](/ja/docs/Web/CSS/CSS_Shapes/From_box_values#padding-box)を参照ボックスとして使用します。 - `content-box` - : [コンテンボックス](/ja/docs/Web/CSS/CSS_Shapes/From_box_values#content-box)を参照ボックスとして使用します。 - `fill-box` - : オブジェクトの境界ボックスを参照ボックスとして使用します。 - `stroke-box` - : ストロークの境界ボックスを参照ボックスとして使用します。 - `view-box` - : 最も近い SVG のビューポートを参照ボックスとして使用します。 SVG のビューポートを作成する要素に {{SVGAttr("viewBox")}} 属性が指定されている場合、参照ボックスは `viewBox` 属性で指定された座標系の原点に位置し、参照ボックスの寸法は `viewBox` 属性の width および height 値に設定されます。 - `none` - : クリッピングパスは作成されません。 > **Note:** 計算値が **`none`** 以外の場合は、新しい[重ね合わせコンテキスト](/ja/docs/Web/CSS/CSS_Positioning/Understanding_z_index/The_stacking_context)を生成します。これは、 {{cssxref("opacity")}} が `1` 以外の値の場合と同様です。 ## 公式定義 {{cssinfo}} ## 形式文法 {{csssyntax}} ## 例

HTML と SVG の比較

```html hidden
clip-path: none
HTML

I LOVE
clipping

SVG
I LOVE clipping
clip-path: url(#myPath)

Assuming the following clipPath definition:
<svg>
  <clipPath id="myPath" clipPathUnits="objectBoundingBox">
    <path d="M0.5,1
      C 0.5,1,0,0.7,0,0.3
      A 0.25,0.25,1,1,1,0.5,0.3
      A 0.25,0.25,1,1,1,1,0.3
      C 1,0.7,0.5,1,0.5,1 Z" />
  </clipPath>
</svg>
HTML

I LOVE
clipping

SVG
I LOVE clipping
clip-path: path('M15,45 A30,30,0,0,1,75,45 A30,30,0,0,1,135,45 Q135,90,75,130 Q15,90,15,45 Z')
HTML

I LOVE
clipping

SVG
I LOVE clipping
clip-path: circle(25%)
HTML

I LOVE
clipping

SVG
I LOVE clipping
clip-path: circle(25% at 25% 25%)
HTML

I LOVE
clipping

SVG
I LOVE clipping
clip-path: fill-box circle(25% at 25% 25%)
HTML

I LOVE
clipping

SVG
I LOVE clipping
clip-path: stroke-box circle(25% at 25% 25%)
HTML

I LOVE
clipping

SVG
I LOVE clipping
clip-path: view-box circle(25% at 25% 25%)
HTML

I LOVE
clipping

SVG
I LOVE clipping
clip-path: margin-box circle(25% at 25% 25%)
HTML

I LOVE
clipping

SVG
I LOVE clipping
clip-path: border-box circle(25% at 25% 25%)
HTML

I LOVE
clipping

SVG
I LOVE clipping
clip-path: padding-box circle(25% at 25% 25%)
HTML

I LOVE
clipping

SVG
I LOVE clipping
clip-path: content-box circle(25% at 25% 25%)
HTML

I LOVE
clipping

SVG
I LOVE clipping
``` ```css html,body { height: 100%; box-sizing: border-box; background: #EEE; } .grid { width: 100%; height: 100%; display: flex; font: 1em monospace; } .row { display: flex; flex: 1 auto; flex-direction: row; flex-wrap: wrap; } .col { flex: 1 auto; } .cell { margin: .5em; padding: .5em; background-color: #FFF; overflow: hidden; text-align: center; flex: 1; } .note { background: #fff3d4; padding: 1em; margin: .5em .5em 0; font: .8em sans-serif; text-align: left; white-space: nowrap; } .note + .row .cell { margin-top: 0; } .container { display: inline-block; border: 1px dotted grey; position:relative; } .container:before { content: 'margin'; position: absolute; top: 2px; left: 2px; font: italic .6em sans-serif; } .viewbox { box-shadow: 1rem 1rem 0 #EFEFEF inset, -1rem -1rem 0 #EFEFEF inset; } .container.viewbox:after { content: 'viewbox'; position: absolute; left: 1.1rem; top: 1.1rem; font: italic .6em sans-serif; } .cell span { display: block; margin-bottom: .5em; } p { font-family: sans-serif; background: #000; color: pink; margin: 2em; padding: 3em 1em; border: 1em solid pink; width: 6em; } .none { clip-path: none; } .svg { clip-path: url(#myPath); } .svg2 { clip-path: path('M15,45 A30,30,0,0,1,75,45 A30,30,0,0,1,135,45 Q135,90,75,130 Q15,90,15,45 Z');} .shape1 { clip-path: circle(25%); } .shape2 { clip-path: circle(25% at 25% 25%); } .shape3 { clip-path: fill-box circle(25% at 25% 25%); } .shape4 { clip-path: stroke-box circle(25% at 25% 25%); } .shape5 { clip-path: view-box circle(25% at 25% 25%); } .shape6 { clip-path: margin-box circle(25% at 25% 25%); } .shape7 { clip-path: border-box circle(25% at 25% 25%); } .shape8 { clip-path: padding-box circle(25% at 25% 25%); } .shape9 { clip-path: content-box circle(25% at 25% 25%); } .defs { width: 0; height: 0; margin: 0; } pre { margin-bottom: 0; } svg { margin: 1em; font-family: sans-serif; width: 192px; height: 192px; } svg rect { stroke: pink; stroke-width: 16px; } svg text { fill: pink; text-anchor: middle; } svg text.em { font-style: italic; } ``` {{EmbedLiveSample("Comparison_of_HTML_and_SVG", "100%", 800, "", "", "example-outcome-frame")}}

完全な例

#### HTML ```html MDN logo ``` #### CSS ```css #clipped { margin-bottom: 20px; clip-path: url(#cross); } ``` ```js hidden const clipPathSelect = document.getElementById("clipPath"); clipPathSelect.addEventListener("change", function (evt) { document.getElementById("clipped").style.clipPath = evt.target.value; }); ``` #### 結果 {{EmbedLiveSample("Complete_example", 230, 250)}} ## 仕様書 {{Specifications}} ## ブラウザーの互換性 {{Compat}} ## 関連情報 - [Shapes in clipping and masking – and how to use them](https://hacks.mozilla.org/2017/06/css-shapes-clipping-and-masking/) - CSS プロパティ: {{cssxref("mask")}}, {{cssxref("filter")}} - [SVG 効果の HTML コンテンツへの適用](/ja/docs/Web/SVG/Applying_SVG_effects_to_HTML_content)
  • SVG 属性: - {{SVGAttr("clip-path")}} - {{SVGAttr("clip-rule")}}