Чистая граница круга градиента CSS
на данный момент у меня есть рабочее решение div (с фиксированной высотой и шириной и фоновым изображением для внешней границы градиента) и псевдо-элемент, расположенный absolute
с фоновым изображением внутренней границы.
.div {
position: relative;
width: 254px;
height: 254px;
border: 2px solid transparent;
border-radius: 50%;
background: url(../img/gradient_border_circle.png) no-repeat 50%;
}
div:before {
content: "";
position: absolute;
top: 50%;
transform: translate(-50%,-50%);
left: 50%;
width: 98px;
height: 98px;
border-radius: 50%;
background: url(../img/gradient_border_circle_inner.png) no-repeat 50%;
}
однако я ищу более элегантное решение (чистый CSS или SVG градиент?) без использования фоновых изображений, где градиент может масштабироваться без пикселизация.
Я исследовал и ближе я сталкивался-это https://codepen.io/nordstromdesign/pen/QNrBRM и возможно ли использовать border-radius вместе с border-image, который имеет градиент? но мне нужно решение, где центр прозрачен, чтобы показать фон страницы
Update: в идеале, я ищу решение с относительно хорошей поддержкой во всех современных браузерах.
2 ответов
SVG
- рекомендуемый способ создания формы круга и рисования градиентного контура / границы вокруг него.
SVG
есть circle
элемент, который можно использовать для рисования формы круга. Эта форма может быть заполнена и очерчена сплошным цветом, градиентом или рисунком.
* {box-sizing: border-box;}
body {
background: linear-gradient(#333, #999);
text-align: center;
min-height: 100vh;
padding-top: 10px;
margin: 0;
}
svg {vertical-align: top;}
<svg width="210" height="210">
<defs>
<linearGradient id="grad1" x1="0" y1="1" x2="1" y2="0">
<stop offset="0" stop-color="#f5d700" />
<stop offset="1" stop-color="#0065da" />
</linearGradient>
<linearGradient id="grad2" xlink:href="#grad1" x1="1" y1="0" x2="0" y2="1"></linearGradient>
</defs>
<g fill="none">
<circle cx="100" cy="100" r="95" stroke="url(#grad1)" stroke-width="2" />
<circle cx="100" cy="100" r="40" stroke="url(#grad2)" stroke-width="5" />
</g>
</svg>
можно использовать mask
для достижения того, что вы ищете. Вам понадобится SVG-файл с прозрачным кругом. Здесь я использовал изображение из интернета, но вы можете сделать свой собственный, чтобы удовлетворить ваши потребности:
mask: url(circle.svg);
- CodePen (установите фон на красный, чтобы показать прозрачность)
- ссылка на маску
- создание собственных масок