103 of 313 menu

maskプロパティ

プロパティmaskは、すべてのマスキングプロパティの一括指定であり、以下を設定できます: マスク画像、その位置、サイズ、ブレンドモード、その他のパラメータ。

以下のプロパティの一括指定です: mask-image, mask-position, mask-size, mask-repeat, mask-origin, mask-clip, mask-mode, mask-composite

構文

セレクタ { mask: [mask-image] [mask-position] / [mask-size] [mask-repeat] [mask-origin] [mask-clip] [mask-mode] [mask-composite]; }

説明
none マスキングを無効にする(デフォルト値)
url() マスク画像へのパス(SVG、PNG)
linear-gradient() マスクとしての線形グラデーション
radial-gradient() マスクとしての放射状グラデーション
position マスクの位置(top、center、50% 50%など)
size マスクのサイズ(cover、contain、100px 50px)
repeat マスクの繰り返し(no-repeat、repeat-x、space)
mode ブレンドモード(alpha、luminance、match-source)
composite マスクの合成(add、subtract、intersect、exclude)

画像の準備

切り取る自然の画像と、切り抜きに使用するハートと矢印のSVG画像があるとします:

<img src="image.jpg" width="500"> <br> <img src="heart.svg" width="300"> <br> <img src="arrow.svg" width="300">

:

. 画像マスク

ハート型マスクを画像に適用してみましょう:

<img id="image" src="image.jpg"> #image { width: 500px; height: 281px; background: red; mask: url("heart.svg") center/300px no-repeat; }

:

. マスクの位置

左上のハート型マスク:

<img id="image" src="image.jpg"> #image { width: 500px; height: 281px; mask: url("heart.svg") left top/150px no-repeat; }

:

. マスクの位置

右下のハート型マスク:

<img id="image" src="image.jpg"> #image { width: 500px; height: 281px; mask: url("heart.svg") right bottom/150px no-repeat; }

:

. マスクの位置

左中央のハート型マスク:

<img id="image" src="image.jpg"> #image { width: 500px; height: 281px; mask: url("heart.svg") left center/150px no-repeat; }

:

. マスクの位置

中央のハート型マスク:

<img id="image" src="image.jpg"> #image { width: 500px; height: 281px; mask: url("heart.svg") center/150px no-repeat; }

:

. マスクの位置

左から100px、上から200pxのハート型マスク:

<img id="image" src="image.jpg"> #image { width: 500px; height: 281px; mask: url("heart.svg") 100px 200px /150px no-repeat; }

:

. マスクサイズ cover

coverは、マスクを要素を完全に覆うように拡大縮小し、アスペクト比を保持します。 アスペクト比が一致しない場合、マスクの端を切り取る可能性があります:

<img id="image" src="image.jpg"> #image { width: 500px; height: 281px; mask: url("heart.svg") center/cover; }

:

. マスクサイズ contain

containは、マスクを要素内全体に収まるように拡大縮小し、 アスペクト比を保持します。空の領域が残る可能性があります:

<img id="image" src="image.jpg"> #image { width: 500px; height: 281px; mask: url("heart.svg") center/contain no-repeat; }

:

. マスクサイズ

固定サイズはマスクの正確な寸法を設定します。 例えば、マスクサイズを50pxにしてみましょう:

<img id="image" src="image.jpg"> #image { width: 500px; height: 281px; mask: url("heart.svg") center/50px no-repeat; }

:

. 繰り返し no-repeat

no-repeatはマスクの繰り返しを無効にします。 マスクは指定された位置に一度だけ表示されます:

<img id="image" src="image.jpg"> #image { width: 500px; height: 281px; mask: url("heart.svg") top left / 150px no-repeat; }

:

. 繰り返し repeat-x

repeat-xは、水平軸のみでマスクを繰り返します:

<img id="image" src="image.jpg"> #image { width: 500px; height: 281px; mask: url("heart.svg") left center / 50px repeat-x; }

:

. 合成 add

addは複数のマスクを加算します(結果はすべてのマスクの和集合):

<img id="image" src="image.jpg"> #image { width: 500px; height: 281px; mask: url("heart.svg") 100px 50px / 150px no-repeat, url("arrow.svg") 200px 30px / 150px no-repeat; mask-composite: add; }

:

. 合成 intersect

intersectは、マスクの交差領域のみを表示します:

<img id="image" src="image.jpg"> #image { width: 500px; height: 281px; mask: url("heart.svg") 100px 50px / 150px no-repeat, url("arrow.svg") 50px 30px / 150px no-repeat; mask-composite: intersect; }

:

. 合成 exclude

excludeは、交差していないマスクの領域を表示します:

<img id="image" src="image.jpg"> #image { width: 500px; height: 281px; mask: url("heart.svg") 100px 50px / 150px no-repeat, url("arrow.svg") 50px 30px / 150px no-repeat; mask-composite: exclude; }

:

. 合成 subtract

subtractは、最初のマスクから2番目のマスクを減算します。 例として、1つのハートを作り、そこから矢印を引き算してみましょう:

<img id="image" src="image.jpg"> #image { width: 500px; height: 281px; mask: url("heart.svg") 100px 50px / 250px no-repeat, url("arrow.svg") 170px 80px / 120px no-repeat; mask-composite: subtract; }

:

. maskの詳細な記述

個別の構成プロパティで記述されたmaskプロパティ:

<img id="image" src="image.jpg"> #image { width: 500px; height: 281px; mask-image: url("heart.svg"); mask-position: center; mask-size: contain; mask-repeat: no-repeat; mask-origin: content-box; mask-clip: content-box; mask-mode: alpha; mask-composite: add; }

:

. 画像用SVG

画像用のマスクとしてSVG要素を使用する:

<img id="image" src="image.jpg"> <svg width="0" height="0"> <mask id="mask"> <path d="M150 15L183 111L285 111L204 171L237 267L150 216L63 267L96 171L15 111L117 111Z" fill="white"/> </mask> </svg> #image { width: 500px; height: 281px; background: red; mask: url(#mask); }

:

. グラデーション用SVG

グラデーション用のマスクとしてSVG要素を使用する:

<div id="elem"></div> <svg width="0" height="0"> <mask id="star-mask"> <path d="M150 15L183 111L285 111L204 171L237 267L150 216L63 267L96 171L15 111L117 111Z" fill="white"/> </mask> </svg> #elem { width: 500px; height: 300px; background: linear-gradient(45deg, red, blue); mask: url(#star-mask); }

:

関連項目

  • プロパティmask-position,
    要素に対するマスクの位置を定義
  • プロパティmask-image,
    マスクの画像を指定
  • プロパティmask-mode,
    マスクが背景とどのように相互作用するかを定義
  • プロパティmask-size,
    マスクのサイズを定義
  • プロパティmask-repeat,
    マスクの繰り返しを定義
  • プロパティmask-origin,
    マスクの配置領域を定義
  • プロパティmask-clip,
    マスクのクリッピング領域を定義
  • プロパティmask-composite,
    複数のマスクがどのように組み合わされるかを定義
日本語
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItalianoქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
当サイトでは、サイトの動作、分析、パーソナライゼーションのためにクッキーを使用しています。 データ処理はプライバシーポリシーに従って行われます。
すべて受け入れる 設定 拒否