Вы можете получить прозрачный вырезанный круг с двумя различными методами:
1.SVG
В следующих примерах используется inline svg ,Первый фрагмент использует маску , чтобы вырезать прозрачный круг, а второй полый круг выполнен с элементом пути .Круг состоит из 2 команд дуги :
С элементом маски:
body{background:url('https://farm9.staticflickr.com/8760/17195790401_ceeeafcddb_o.jpg');background-size:cover;}
<svg viewbox="0 0 100 50" width="100%">
<defs>
<mask id="mask" x="0" y="0" width="80" height="30">
<rect x="5" y="5" width="90" height="40" fill="#fff"/>
<circle cx="50" cy="25" r="15" />
</mask>
</defs>
<rect x="0" y="0" width="100" height="50" mask="url(#mask)" fill-opacity="0.7"/>
</svg>
С одним элементом пути:
body{background: url('https://farm9.staticflickr.com/8760/17195790401_ceeeafcddb_o.jpg');background-size:cover;}
svg{
display:block;
width:70%;
height:auto;
margin:0 auto;
}
path{
transition:fill .5s;
fill:#E3DFD2;
}
path:hover{
fill:pink;
}
<svg viewbox="-10 -1 30 12">
<path d="M-10 -1 H30 V12 H-10z M 5 5 m -5, 0 a 5,5 0 1,0 10,0 a 5,5 0 1,0 -10,0z"/>
</svg>
Основными преимуществами использования SVG в этом случае являются:
- более короткий код
- Вы можете легко использоватьизображение или градиент, чтобы заполнить маску круга
- сохранить границы фигуры и активировать мышь только над заливкой, соответствующей маске ( навести прозрачный вырезанный круг в примере)
2.CSS только с использованием BOX-SHADOWS
Создайте div с overflow:hidden;
и круглым псевдоэлементом внутри него с border-radius.Дайте ему огромную коробку-тень и без фона:
div{
position:relative;
width:500px; height:200px;
margin:0 auto;
overflow:hidden;
}
div:after{
content:'';
position:absolute;
left:175px; top:25px;
border-radius:100%;
width:150px; height:150px;
box-shadow: 0px 0px 0px 2000px #E3DFD2;
}
body{background: url('https://farm9.staticflickr.com/8760/17195790401_ceeeafcddb_o.jpg');background-size:cover;}
<div></div>
Поддержка браузеров для теней: IE9 + см. canIuse
Тот же подходиспользовать границу вместо box-shadows.Интересно, если вам нужно поддерживать borowsers, которые не поддерживают box-shadows, такие как IE8.Техника та же, но вам нужно компенсировать верхнее и левое значения, чтобы держать кружок в центре div:
body{
background: url('https://farm9.staticflickr.com/8760/17195790401_ceeeafcddb_o.jpg');
background-size:cover;
}
div{
position:relative;
width:500px; height:200px;
margin:0 auto;
overflow:hidden;
}
div:after{
content:'';
position:absolute;
left:-325px; top:-475px;
border-radius:100%;
width:150px; height:150px;
border:500px solid #E3DFD2;
}
<div></div>