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,
複数のマスクがどのように組み合わされるかを定義