Как сделать чашку с блюдцем на CSS

Как сделать чашку с блюдцем на 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;/*спрятать переполненность*/
}

Как сделать чашку с блюдцем на CSS

Рисуем чай в чашке

<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;/*гибкий контейнер*/
}

Как сделать чашку с блюдцем на CSS

Рисуем ручку у чашки

<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);/*поворот ручки*/
}

Как сделать чашку с блюдцем на CSS

Рисуем блюдце

Чтобы геометрические фигуры не были плоскими, добавим два псевдоэлемента с линейными градиентами и тенями. Градиенты и тени делают фигуры фактурными и выразительными.

<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);/*радиальный градиент*/
}

Как сделать чашку с блюдцем на CSS

Источник

Статьи по теме

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *

Этот сайт использует Akismet для борьбы со спамом. Узнайте, как обрабатываются ваши данные комментариев.

Back to top button