Proprietatea mask
Proprietatea mask este o prescurtare pentru toate proprietățile de mascare și permite setarea:
unei imagini-mască, poziției acesteia, dimensiunii, modului de amestec și a altor parametri.
Este o proprietate-prescurtare pentru următoarele proprietăți:
mask-image,
mask-position,
mask-size,
mask-repeat,
mask-origin,
mask-clip,
mask-mode,
mask-composite.
Sintaxă
selector {
mask: [mask-image] [mask-position] / [mask-size]
[mask-repeat] [mask-origin] [mask-clip]
[mask-mode] [mask-composite];
}
Valori
| Valoare | Descriere |
|---|---|
none |
Dezactivează mascarea (valoarea implicită) |
url() |
Calea către imaginea-mască (SVG, PNG) |
linear-gradient() |
Gradient linear ca mască |
radial-gradient() |
Gradient radial ca mască |
position |
Poziția măștii (top, center, 50% 50% etc.) |
size |
Dimensiunea măștii (cover, contain, 100px 50px) |
repeat |
Repetarea măștii (no-repeat, repeat-x, space) |
mode |
Modul de amestec (alpha, luminance, match-source) |
composite |
Compunerea măștilor (add, subtract, intersect, exclude) |
Pregătirea imaginilor
Să presupunem că avem o imagine cu natură pe care o vom decupa și imagini SVG cu o inimioară și o săgeată, după care vom decupa:
<img src="image.jpg" width="500">
<br>
<img src="heart.svg" width="300">
<br>
<img src="arrow.svg" width="300">
:
Exemplu . Mască-imagine
Să aplicăm masca-inimioară pe imaginea noastră:
<img id="image" src="image.jpg">
#image {
width: 500px;
height: 281px;
background: red;
mask: url("heart.svg") center/300px no-repeat;
}
:
Exemplu . Poziția măștii
Masca-inimioară în colțul din stânga sus:
<img id="image" src="image.jpg">
#image {
width: 500px;
height: 281px;
mask: url("heart.svg") left top/150px no-repeat;
}
:
Exemplu . Poziția măștii
Masca-inimioară în colțul din dreapta jos:
<img id="image" src="image.jpg">
#image {
width: 500px;
height: 281px;
mask: url("heart.svg") right bottom/150px no-repeat;
}
:
Exemplu . Poziția măștii
Masca-inimioară în centru spre stânga:
<img id="image" src="image.jpg">
#image {
width: 500px;
height: 281px;
mask: url("heart.svg") left center/150px no-repeat;
}
:
Exemplu . Poziția măștii
Masca-inimioară în centru:
<img id="image" src="image.jpg">
#image {
width: 500px;
height: 281px;
mask: url("heart.svg") center/150px no-repeat;
}
:
Exemplu . Poziția măștii
Masca-inimioară la 100px din stânga și 200px de sus:
<img id="image" src="image.jpg">
#image {
width: 500px;
height: 281px;
mask: url("heart.svg") 100px 200px /150px no-repeat;
}
:
Exemplu . Dimensiunea măștii cover
Valoarea cover scalează masca astfel încât să acopere complet elementul, păstrând proporțiile.
Poate decupa marginile măștii dacă proporțiile nu coincid:
<img id="image" src="image.jpg">
#image {
width: 500px;
height: 281px;
mask: url("heart.svg") center/cover;
}
:
Exemplu . Dimensiunea măștii contain
Valoarea contain scalează masca astfel încât să încapă în întregime în element,
păstrând proporțiile. Poate lăsa zone goale:
<img id="image" src="image.jpg">
#image {
width: 500px;
height: 281px;
mask: url("heart.svg") center/contain no-repeat;
}
:
Exemplu . Dimensiunea măștii
Dimensiunea fixă stabilește dimensiunile exacte ale măștii.
de exemplu, să facem masca cu dimensiunea de 50px:
<img id="image" src="image.jpg">
#image {
width: 500px;
height: 281px;
mask: url("heart.svg") center/50px no-repeat;
}
:
Exemplu . Repetarea no-repeat
Valoarea no-repeat dezactivează repetarea măștii.
Masca este afișată o singură dată în poziția indicată:
<img id="image" src="image.jpg">
#image {
width: 500px;
height: 281px;
mask: url("heart.svg") top left / 150px no-repeat;
}
:
Exemplu . Repetarea repeat-x
Valoarea repeat-x repetă masca doar pe axa orizontală:
<img id="image" src="image.jpg">
#image {
width: 500px;
height: 281px;
mask: url("heart.svg") left center / 50px repeat-x;
}
:
Exemplu . Compunerea add
Valoarea add adună mai multe măști (rezultatul - uniunea tuturor măștilor):
<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;
}
:
Exemplu . Compunerea intersect
Valoarea intersect arată doar zona de intersecție a măștilor:
<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;
}
:
Exemplu . Compunerea exclude
Valoarea exclude arată zonele măștilor care nu se intersectează:
<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;
}
:
Exemplu . Compunerea subtract
Valoarea subtract scade a doua mască din prima.
De exemplu, să facem o inimioară și să scădem din
ea săgeata:
<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;
}
:
Exemplu . Scrierea extinsă a lui mask
Proprietatea mask, scrisă cu componente separate:
<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;
}
:
Exemplu . SVG pentru imagine
Utilizarea unui element SVG ca mască pentru imagine:
<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);
}
:
Exemplu . SVG pentru gradient
Utilizarea unui element SVG ca mască pentru gradient:
<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);
}
:
Vezi și
-
proprietatea
mask-position,
definește poziția măștii relativ la element -
proprietatea
mask-image,
setează imaginea pentru mască -
proprietatea
mask-mode,
definește cum masca interacționează cu fundalul -
proprietatea
mask-size,
definește dimensiunea măștii -
proprietatea
mask-repeat,
definește repetarea măștii -
proprietatea
mask-origin,
definește zona de poziționare a măștii -
proprietatea
mask-clip,
definește zona de decupare a măștii -
proprietatea
mask-composite,
definește cum se combină mai multe măști