Как сделать чашку с блюдцем на CSS
Казалось бы, как можно из HTML тегов и CSS стилей нарисовать что-то посложнее, чем простые геометрические фигуры. Это мы сейчас и узнаем.
Рисуем чашку
//HTML теги
<div class="container">
<div class="cup">
<div class="top">
<div class="circle">
...
</div>
</div>
//CSS стили
*{
margin: 0;
padding: 0;
box-sizing: border-box;
}
body{
display: flex;
justify-content: center;
align-items: center;
background: #607d8b;
min-height: 100vh;
}
.container{
position: relative;
top: 50px;
}
.cup{
position: relative;/*относительное позиционирование*/
width: 280px;/*ширина чашки*/
height: 300px;/*высота чашки*/
background: linear-gradient(to right,#f9f9f9,#d9d9d9);/*линейный градиент слева направо*/
border-bottom-left-radius: 45%;/*закругление левого нижнего угла*/
border-bottom-right-radius: 45%;/*закругление правого нижнего угла*/
}
.cup .top .circle{
content: '';
position: absolute;/*абсолютное позиционирование*/
top: 5px;/*позиция сверху*/
left: 10px;/*позиция слева*/
width: calc(100% - 20px);/*ширина верха кружки*/
height: 50px;/*высота верха кружки*/
background: linear-gradient(to left,#f9f9f9,#d9d9d9);/*линейный градиент справа налево*/
border-radius: 50%;/*все углы закруглены*/
box-sizing: border-box;/*реальный размер блока*/
overflow: hidden;/*спрятать переполненность*/
}
Рисуем чай в чашке
<div class="circle">
<div class="tea"></div>
</div>
.tea{
position: absolute;
top: 20px;
left: 0;
width: 100%;
height: 100%;
background: radial-gradient( #c57e65, #e28462);/*радиальный градиент*/
border-radius: 50%;/*все углы закруглены*/
display: flex;/*гибкий контейнер*/
}
Рисуем ручку у чашки
<div class="handle"></div>
.handle{
position: absolute;
right: -70px;
top: 40px;
width: 160px;/*ширина ручки*/
height: 180px;/*высота ручки*/
border-left: 25px solid transparent;/*левая сторона ручки прозрачная*/
border-bottom: 25px solid transparent;/*низ ручки прозрачный*/
border-top: 25px solid #dcdcdc;/*верхняя часть ручки*/
border-right: 25px solid #dcdcdc;/*правая часть ручки*/
border-radius: 50%;/*все углы закруглены*/
transform: rotate(42deg);/*поворот ручки*/
}
Рисуем блюдце
Чтобы геометрические фигуры не были плоскими, добавим два псевдоэлемента с линейными градиентами и тенями. Градиенты и тени делают фигуры фактурными и выразительными.
<div class="plate"></div>
.plate{
position: absolute;
bottom: -50px;
left: 50%;
transform: translateX(-50%);/*смещение по горизонтали*/
width: 500px;/*ширина блюдца*/
height: 200px;/*высота блюдца*/
border-radius: 50%;/*закругленные углы*/
background: linear-gradient(to right,#f9f9f9,#e7e7e7);/*линейный градиент слева направо*/
box-shadow: 0 35px 35px rgba(0,0,0,0.2);/*тень у бокса*/
}
.plate:before{
content: '';
position: absolute;
top: 10px;
left: 10px;
right: 10px;
bottom: 10px;
border-radius: 50%;
background: linear-gradient(to left,#f9f9f9,#e7e7e7);/*линейный градиент справа налево*/
}
.plate:after{
content: '';
position: absolute;
top: 30px;
left: 30px;
right: 30px;
bottom: 30px;
border-radius: 50%;
background: radial-gradient(rgba(0,0,0,0.2) 25%, transparent, transparent);/*радиальный градиент*/
}
-
- Михаил Русаков
Комментарии (0):
Для добавления комментариев надо войти в систему.
Если Вы ещё не зарегистрированы на сайте, то сначала зарегистрируйтесь.