Сердце, сердечный ритм и анимированные шестерни с css

Это наш логотип: Сердце, сердечный ритм и анимированные шестерни с css

Мы хотели бы создать его с помощью css и анимировать шестеренку, но, как вы можете видеть, запустив мой код, я борюсь со следующим:

  • сердце не в шестерне
  • если я помещаю div сердца в шестеренку, для которой она анимируется, но только шестеренка должна анимировать
  • в настоящее время частота сердечных сокращений (синяя линия) не выполняется с помощью css, потому что я не знаю, как решить эту проблему

Вы знаете, как это решить?

body{background: #fff;}

.parent{
  display: flex;
  height: 500px;
}

.gear{
  position: relative;
  width: 200px;
  height: 200px;
  margin: auto;
  background: black;
  border-radius: 50%;
  animation-name: spin;
  animation-duration: 4s;
  animation-iteration-count: infinite;
  animation-timing-function: linear;
}

.gear .center{
  position: absolute;
  top: 25px;
  left: 25px;
  z-index: 10;
  width: 150px;
  height: 150px;
  background: #fff;
  border-radius: 50%;
}

.tooth{
  position: absolute;
  top: -25px;
  left: 75px;
  z-index: 1;
  width: 45px;
  height: 250px;
  background:black;
}

.tooth:nth-child(2){
  transform: rotate(45deg);
}

.tooth:nth-child(3){
  transform: rotate(90deg);
}

.tooth:nth-child(4){
  transform: rotate(135deg);
}

@keyframes spin {
  from {transform: rotate(0deg); }
  to {transform: rotate(360deg);}
}

#heart {
 position: relative;
 width: 100px;
 height: 90px;
}

#heart:before,
#heart:after {
 position: absolute;
 content: "";
 left: 50px;
 top: 0;
 width: 50px;
 height: 80px;
 background: #1D74BA;
 -moz-border-radius: 50px 50px 0 0;
 border-radius: 50px 50px 0 0;
 -webkit-transform: rotate(-45deg);
 -moz-transform: rotate(-45deg);
 -ms-transform: rotate(-45deg);
 -o-transform: rotate(-45deg);
 transform: rotate(-45deg);
 -webkit-transform-origin: 0 100%;
 -moz-transform-origin: 0 100%;
 -ms-transform-origin: 0 100%;
 -o-transform-origin: 0 100%;
 transform-origin: 0 100%;
}

#heart:after {
 left: 0;
 -webkit-transform: rotate(45deg);
 -moz-transform: rotate(45deg);
 -ms-transform: rotate(45deg);
 -o-transform: rotate(45deg);
 transform: rotate(45deg);
 -webkit-transform-origin: 100% 100%;
 -moz-transform-origin: 100% 100%;
 -ms-transform-origin: 100% 100%;
 -o-transform-origin: 100% 100%;
 transform-origin :100% 100%;
}



svg.heart-rate{
  position: absolute;
  z-index:999;
  transform: scale(0.6);
  color:white;
  fill: currentColor;
}
<div class = "parent">
  <div id = "heart">
  <svg class = "heart-rate" ersion = "1.0" xmlns = "http://www.w3.org/2000/svg" xmlns:xlink = "http://www.w3.org/1999/xlink" x = "0px" y = "0px" width = "150px" height = "73px" viewBox = "0 0 150 73" enable-background = "new 0 0 150 73" xml:space = "preserve">
    <polyline fill = "none" stroke = "#009B9E" stroke-width = "3" stroke-miterlimit = "10" points = "0,45.486 38.514,45.486 44.595,33.324 50.676,45.486 57.771,45.486 62.838,55.622 71.959,9 80.067,63.729 84.122,45.486 97.297,45.486 103.379,40.419 110.473,45.486 150,45.486"
    />
  </svg>
</div>
  <div class = "gear">
    <div class = "center"></div>
    <div class = "tooth"></div>
    <div class = "tooth"></div>
    <div class = "tooth"></div>
    <div class = "tooth"></div>
  </div>  
</div>
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Введение в CSS
Введение в CSS
CSS является неотъемлемой частью трех основных составляющих front-end веб-разработки.
Как выровнять Div по центру?
Как выровнять Div по центру?
Чтобы выровнять элемент <div>по горизонтали и вертикали с помощью CSS, можно использовать комбинацию свойств и значений CSS. Вот несколько методов,...
Навигация по приложениям React: Исчерпывающее руководство по React Router
Навигация по приложениям React: Исчерпывающее руководство по React Router
React Router стала незаменимой библиотекой для создания одностраничных приложений с навигацией в React. В этой статье блога мы подробно рассмотрим...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
CSS: FlexBox
CSS: FlexBox
Ранее разработчики использовали макеты с помощью Position и Float. После появления flexbox сценарий полностью изменился.
5
0
702
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Используйте position:absolute на сердце и поместите его в центре родителя, используя top, left и transform.

body {
  background: #fff;
}

.parent {
  display: flex;
  height: 500px;
  position:relative;
}

.gear {
  position: relative;
  width: 200px;
  height: 200px;
  margin: auto;
  background: black;
  border-radius: 50%;
  animation-name: spin;
  animation-duration: 4s;
  animation-iteration-count: infinite;
  animation-timing-function: linear;
}

.gear .center {
  position: absolute;
  top: 25px;
  left: 25px;
  z-index: 10;
  width: 150px;
  height: 150px;
  background: #fff;
  border-radius: 50%;
}

.tooth {
  position: absolute;
  top: -25px;
  left: 75px;
  z-index: 1;
  width: 45px;
  height: 250px;
  background: black;
}

.tooth:nth-child(2) {
  transform: rotate(45deg);
}

.tooth:nth-child(3) {
  transform: rotate(90deg);
}

.tooth:nth-child(4) {
  transform: rotate(135deg);
}

@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

#heart {
  position: absolute;
    width: 100px;
    height: 90px;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    z-index: 9999;
    margin-top:10px;
}

#heart:before,
#heart:after {
  position: absolute;
  content: "";
  left: 50px;
  top: 0;
  width: 50px;
  height: 80px;
  background: #1D74BA;
  -moz-border-radius: 50px 50px 0 0;
  border-radius: 50px 50px 0 0;
  -webkit-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  -o-transform: rotate(-45deg);
  transform: rotate(-45deg);
  -webkit-transform-origin: 0 100%;
  -moz-transform-origin: 0 100%;
  -ms-transform-origin: 0 100%;
  -o-transform-origin: 0 100%;
  transform-origin: 0 100%;
}

#heart:after {
  left: 0;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  transform: rotate(45deg);
  -webkit-transform-origin: 100% 100%;
  -moz-transform-origin: 100% 100%;
  -ms-transform-origin: 100% 100%;
  -o-transform-origin: 100% 100%;
  transform-origin: 100% 100%;
}

svg.heart-rate {
     position: absolute;
    z-index: 999;
    color: white;
    fill: currentColor;
    left: 50%;
    top: 40%;
    transform: translate(-50%,-50%) scale(0.6);
}
<div class = "parent">
  <div id = "heart">
    <svg class = "heart-rate" ersion = "1.0" xmlns = "http://www.w3.org/2000/svg" xmlns:xlink = "http://www.w3.org/1999/xlink" x = "0px" y = "0px" width = "150px" height = "73px" viewBox = "0 0 150 73" enable-background = "new 0 0 150 73" xml:space = "preserve">
    <polyline fill = "none" stroke = "#fff" stroke-width = "3" stroke-miterlimit = "10" points = "0,45.486 38.514,45.486 44.595,33.324 50.676,45.486 57.771,45.486 62.838,55.622 71.959,9 80.067,63.729 84.122,45.486 97.297,45.486 103.379,40.419 110.473,45.486 150,45.486"
    />
  </svg>
  </div>
  <div class = "gear">
    <div class = "center"></div>
    <div class = "tooth"></div>
    <div class = "tooth"></div>
    <div class = "tooth"></div>
    <div class = "tooth"></div>
  </div>
</div>

Замечательно, большое спасибо за это! У вас есть идеи, как сделать голубую линию сердечного ритма с помощью css?

Krystian 22.03.2018 12:40

@KrystianManthey, вы можете использовать то же самое, используйте абсолютное положение и верхнее / левое положение, куда хотите :), вы можете увидеть мое обновление!

Chiller 22.03.2018 12:48

Я имел в виду, знаете ли вы, как вместо этого сделать этот heartrate-svg с помощью css? Потому что на самом деле он должен быть белым, а не голубым. В любом случае я приму ваш ответ! :-)

Krystian 22.03.2018 12:59

@KrystianManthey вы можете изменить цвет svg stroke = "#fff", см. Мое обновление

Chiller 22.03.2018 13:06

Другие вопросы по теме