CSS<basic-shape> データ型は、 clip-path, shape-outside, offset-path の各プロパティで使用されるシェイプを表します。

構文

<basic-shape> データ型は、以下に挙げた基本シェイプ関数のうちの一つで定義します。

シェイプを作成するときは、 <basic-shape> の値を使用するそれぞれのプロパティで参照ボックスを定義します。シェイプの座標系は参照ボックスの左上隅が原点で、 X 座標が右方向、 Y 座標が下方向になります。パーセント値で表現された長さはすべて、参照ボックスの寸法を使用して算出されます。

シェイプ関数

以下のシェイプに対応しています。 <basic-shape> 値はすべて関数表記であり、 値定義構文で定義されます。

inset()
inset( <shape-arg>{1,4} [round <border-radius>]? )

内部の長方形を定義します。

最初の4つの引数が与えられたときは、参照ボックス内部のそれぞれ上、右、下、左からみた、内部の矩形における各辺の位置を定義するオフセットを表します。これらの引数は margin 一括指定プロパティの構文に従い、1つ、2つ、4つの値で全四辺を設定することができます。

<border-radius> の引数は省略可能で、 border-radius 一括指定プロパティの構文を使用して、内部の矩形の角の丸みを定義します。

内部の矩形で2つの距離の組み合わせが、その軸の長さを超えていた場合(たとえば左右の距離がそれぞれ75%に設定された場合など)は、何も領域を囲まないシェイプを定義します。この仕様書によれば、これは空のフロート領域を生成します。

circle()
circle( [<shape-radius>]? [at <position>]? )

引数 <shape-radius>r、つまり円の半径を表します。負の数は無効です。ここでパーセント値を指定すると、参照ボックスの幅と高さを使用して sqrt(width^2+height^2)/sqrt(2) としての割合になります。

引数 <position> は円の中心を定義します。省略時は既定で中央になります。

ellipse()
ellipse( [<shape-radius>{2}]? [at <position>]? )

引数 <shape-radius> は、 rx と ry、つまり楕円の横半径と縦半径を、この順で表します。どちらの半径も負の値は無効です。ここでパーセント値を指定すると、参照ボックスの幅(rx 値の場合)と高さ(ry 値の場合)に対する割合になります。

引数 position は楕円の中心を定義します。省略時は既定で中央になります。

polygon()
polygon( [<fill-rule>,]? [<shape-arg> <shape-arg>]# )

<fill-rule> は多角形の内部を決めるために使用される塗りつぶし規則を表します。指定可能な値は nonzeroevenodd です。省略時の既定値は nonzero です。

それぞれの shape-arg の組における引数 xiyi は、多角形の i 番目の頂点の座標を表します。

path()
path( [<fill-rule>,]? <string>)

省略可能な <fill-rule> は、パスの内部を決めるために使用される塗りつぶし規則を表します。指定可能な値は nonzeroevenodd です。省略時の既定値は nonzero です。

必須の <string> は、引用符で囲まれた SVG Path です。

上記で定義されていない引数は、以下のように定義されています。

<shape-arg> = <length> | <percentage>
<shape-radius> = <length> | <percentage> | closest-side | farthest-side

円や楕円の半径を定義します。省略時の既定値は closest-side です。

closest-side はシェイプの中心から参照ボックスの最も近い辺までの距離を使用します。円の場合、これはあらゆる方向で最も近い辺です。楕円の場合、その軸で最も近い辺です。

farthest-side はシェイプの中心から参照ボックスの最も遠い辺までの距離を使用します。円の場合、これはあらゆる方向で最も遠い辺です。楕円の場合、その軸で最も遠い辺です。

基本シェイプの計算値

<basic-shape> 関数での値は以下の例外を除けば、規定通りに計算されます。

  • 省略された値は既定値として含められ計算されます。
  • circle() または ellipse() における <position> 値は、それぞれを絶対的な長さやパーセント値で指定し、左上を原点とした(水平と垂直)オフセットの組として計算されます。
  • inset() での <border-radius> 値は全8つの length またはパーセント値の展開リストとして計算されます。

基本シェイプの補間

 ある <basic-shape> と他のものの間でアニメーションが行われるとき、以下の規則が適用されます。シェイプ関数の中の値は単なるリストとして補間が行われます。リストの値は可能であれば <length><percentage>calc() として補間されます。リストの値がこれらの型以外で同じであれば(両方のリストの同じ位置に nonzero があった場合など)、それらの値は補間が行われます。

  • どちらのシェイプも同じ参照ボックスを使う必要があります。
  • 両方のシェイプが同じ型で、型が ellipse() または circle() で、半径に closest-side または farthest-side のキーワードが使われていない場合、シェイプ関数のそれぞれの値の間で補間が行われます。
  • 両方のシェイプの型が inset() の場合、シェイプ関数のそれぞれの値の間で補間が行われます。
  • 両方のシェイプの型が polygon() で、両方の多角形が同じ数の角を持っており、同じ <fill-rule> を使用している場合、シェイプ関数のそれぞれの値の間で補間が行われます。
  • 両方のシェイプの型が path() の場合、両方の文字列が同じ数でパスデータコマンドの型が同じ順序であれば、実数でそれぞれのパスデータコマンドが補間されます。
  • それ以外の場合は補間が行われません。

アニメーションする多角形

この例では、 @keyframes @-規則を使用して、二つの多角形の間でクリップパスをアニメーションします。なお、どちらの多角形も同じ数の角を持つことが、この種のアニメーションが動作するために必要です。

HTML

<div></div>

CSS

div {
  width: 300px;
  height: 300px;
  background: repeating-linear-gradient(red, orange 50px);
  clip-path: polygon(50% 0%, 60% 40%, 100% 50%, 60% 60%, 50% 100%, 40% 60%, 0% 50%, 40% 40%);
  animation: 4s poly infinite alternate ease-in-out;
  margin: 10px auto;
}

@keyframes poly {
  from {
    clip-path: polygon(50% 0%, 60% 40%, 100% 50%, 60% 60%, 50% 100%, 40% 60%, 0% 50%, 40% 40%);
  }

  to {
    clip-path: polygon(50% 30%, 100% 0%, 70% 50%, 100% 100%, 50% 70%, 0% 100%, 30% 50%, 0% 0%);
  }
}

結果

仕様書

仕様書 状態 備考
CSS Shapes Module Level 1
<basic-shape> の定義
勧告候補 初回定義

ブラウザーの対応

Update compatibility data on GitHub
デスクトップモバイル
ChromeEdgeFirefoxInternet ExplorerOperaSafariAndroid webviewAndroid 版 ChromeEdge MobileAndroid 版 FirefoxAndroid 版 OperaiOSのSafariSamsung Internet
基本対応Chrome 完全対応 37Edge ? Firefox 完全対応 61
無効
完全対応 61
無効
無効 From version 61: this feature is behind the layout.css.shape-outside.enabled preference (needs to be set to true). To change preferences in Firefox, visit about:config.
IE 未対応 なしOpera 完全対応 24Safari 完全対応 10.1WebView Android 完全対応 37Chrome Android 完全対応 37Edge Mobile ? Firefox Android 完全対応 61
無効
完全対応 61
無効
無効 From version 61: this feature is behind the layout.css.shape-outside.enabled preference (needs to be set to true). To change preferences in Firefox, visit about:config.
Opera Android 完全対応 24Safari iOS 完全対応 10.3Samsung Internet Android 完全対応 4.0
inset()Chrome 完全対応 37Edge ? Firefox 完全対応 61
無効
完全対応 61
無効
無効 From version 61: this feature is behind the layout.css.shape-outside.enabled preference (needs to be set to true). To change preferences in Firefox, visit about:config.
IE 未対応 なしOpera 完全対応 24Safari 完全対応 10.1WebView Android 完全対応 37Chrome Android 完全対応 37Edge Mobile ? Firefox Android 完全対応 61
無効
完全対応 61
無効
無効 From version 61: this feature is behind the layout.css.shape-outside.enabled preference (needs to be set to true). To change preferences in Firefox, visit about:config.
Opera Android 完全対応 24Safari iOS 完全対応 10.3Samsung Internet Android 完全対応 4.0
circle()Chrome 完全対応 37Edge ? Firefox 完全対応 61
無効
完全対応 61
無効
無効 From version 61: this feature is behind the layout.css.shape-outside.enabled preference (needs to be set to true). To change preferences in Firefox, visit about:config.
IE 未対応 なしOpera 完全対応 24Safari 完全対応 10.1WebView Android 完全対応 37Chrome Android 完全対応 37Edge Mobile ? Firefox Android 完全対応 61
無効
完全対応 61
無効
無効 From version 61: this feature is behind the layout.css.shape-outside.enabled preference (needs to be set to true). To change preferences in Firefox, visit about:config.
Opera Android 完全対応 24Safari iOS 完全対応 10.3Samsung Internet Android 完全対応 4.0
polygon()Chrome 完全対応 37Edge ? Firefox 完全対応 61
無効
完全対応 61
無効
無効 From version 61: this feature is behind the layout.css.shape-outside.enabled preference (needs to be set to true). To change preferences in Firefox, visit about:config.
IE 未対応 なしOpera 完全対応 24Safari 完全対応 10.1WebView Android 完全対応 37Chrome Android 完全対応 37Edge Mobile ? Firefox Android 完全対応 61
無効
完全対応 61
無効
無効 From version 61: this feature is behind the layout.css.shape-outside.enabled preference (needs to be set to true). To change preferences in Firefox, visit about:config.
Opera Android 完全対応 24Safari iOS 完全対応 10.3Samsung Internet Android 完全対応 4.0
path()Chrome 部分対応 46
補足
部分対応 46
補足
補足 Only supported on the offset-path property.
Edge ? Firefox 部分対応 63
補足 無効
部分対応 63
補足 無効
補足 Only supported on the clip-path and offset-path properties.
無効 From version 63: this feature is behind the layout.css.clip-path-path.enabled preference (needs to be set to true). To change preferences in Firefox, visit about:config.
IE 未対応 なしOpera 部分対応 一部
補足
部分対応 一部
補足
補足 Only supported on the offset-path property.
Safari 未対応 なしWebView Android 部分対応 46
補足
部分対応 46
補足
補足 Only supported on the offset-path property.
Chrome Android 部分対応 46
補足
部分対応 46
補足
補足 Only supported on the offset-path property.
Edge Mobile ? Firefox Android 部分対応 63
補足 無効
部分対応 63
補足 無効
補足 Only supported on the clip-path and offset-path properties.
無効 From version 63: this feature is behind the layout.css.clip-path-path.enabled preference (needs to be set to true). To change preferences in Firefox, visit about:config.
Opera Android 部分対応 一部
補足
部分対応 一部
補足
補足 Only supported on the offset-path property.
Safari iOS 未対応 なしSamsung Internet Android 部分対応 一部
補足
部分対応 一部
補足
補足 Only supported on the offset-path property.
AnimationChrome 完全対応 37Edge ? Firefox 完全対応 61
無効
完全対応 61
無効
無効 From version 61: this feature is behind the layout.css.shape-outside.enabled preference (needs to be set to true). To change preferences in Firefox, visit about:config.
IE 未対応 なしOpera 完全対応 24Safari 完全対応 10.1WebView Android 完全対応 37Chrome Android 完全対応 37Edge Mobile ? Firefox Android 完全対応 61
無効
完全対応 61
無効
無効 From version 61: this feature is behind the layout.css.shape-outside.enabled preference (needs to be set to true). To change preferences in Firefox, visit about:config.
Opera Android 完全対応 24Safari iOS 完全対応 10.3Samsung Internet Android 完全対応 4.0

凡例

完全対応  
完全対応
部分対応  
部分対応
未対応  
未対応
実装状況不明  
実装状況不明
実装ノートを参照してください。
実装ノートを参照してください。
ユーザーが明示的にこの機能を有効にしなければなりません。
ユーザーが明示的にこの機能を有効にしなければなりません。

関連情報

ドキュメントのタグと貢献者

このページの貢献者: mfuji09
最終更新者: mfuji09,