Хобрук: Ваш путь к мастерству в программировании

Повернуть svg-путь по кругу

Я хочу повернуть многоугольник вокруг круга. Я хочу зафиксировать начальную точку многоугольника в центре круга следующим образом: http://www.enspiregroup.com . Я много пробовал, но застрял.

См. код ниже.

CSS и HTML5

    .circle-segment {
        position: absolute;
        top: 0;
        width: 260px;
        height: 260px;
    }
    div .circle-wrap {
        position: absolute;
        max-width: 360px;
        margin: 0 auto;
        top: 107px;
        left: 29.7%;
    }
    main.css:1032
    .circle-wrap {
        width: 362px;
        height: 362px;
    }
    .main-circle {
        position: relative;
        height: 300px;
        width: 300px;
        background-color: #0c272e;
        border-radius: 50%;
        margin: 15px auto;
    }
  <?xml version="1.0"?>
    <div class="circle-wrap">
        <div class="main-circle">
           <svg class="circle-segment" class="circle-wrap"
           xmlns="http://www.w3.org/2000/svg" version="1.1"
           xmlns:xlink="http://www.w3.org/1999/xlink" >
           <path id="little" d="M180,180 v-180 a180,180 0 0,0 -180,180 z"        
           fill="#066a8e"></path>
           <animateTransform attributeName="transform"
                          attributeType="XML"
                          type="rotate"
                          from="00 60 70"
                          to="360 60 70"
                          dur="10s"
                          repeatCount="indefinite"/>
    
              </svg>
        </div>
    </div>

    

23.01.2018

Ответы:


1

Я не знаю, почему сайт, на который вы ссылаетесь, использует смесь HTML и SVG для создания этой анимации. Но это, конечно, не простой способ добиться этого.

Гораздо проще просто поместить круг в SVG.

.circle-segment {
  width: 360px;
  height: 360px;
}
<div class="circle-wrap">
  <div class="main-circle">

    <svg class="circle-segment" class="circle-wrap"
         xmlns="http://www.w3.org/2000/svg" version="1.1"
         xmlns:xlink="http://www.w3.org/1999/xlink" >
      <circle cx="180" cy="180" r="150" fill="#0c272e"/>
      <path id="little" d="M180,180 v-180 a180,180 0 0,0 -180,180 z"        
            fill="#066a8e">
        <animateTransform attributeName="transform"
                           attributeType="XML"
                           type="rotate"
                           from="00 180 180"
                           to="360 180 180"
                           dur="10s"
                           repeatCount="indefinite"/>
      </path>
    
    </svg>
  </div>
</div>

23.01.2018
  • Вы спасли мой день! Но как добиться той анимации, которая отображается на связанном веб-сайте? 24.01.2018
  • Вы имеете в виду, как он вращается пошагово при прокрутке? Это действительно другой вопрос. Здесь есть ряд вопросов о том, как анимировать при прокрутке. Попробуйте один из них, и если вы застряли, задайте другой вопрос. 24.01.2018

  • 2

    А как насчет преобразования CSS и анимации?

    .main-circle {
      background-color: #0c272e;
      border-radius: 50%;
      height: 300px;
      margin: 15px auto;
      position: relative;
      width: 300px;
    }
    
    svg {
      animation: rotate 5s infinite linear;
      height: 362px;
      left: -31px;
      position: absolute;
      top: -31px;
      width: 362px;
    }
    
    @keyframes rotate {
      100% {
        transform: rotate(360deg);
      }
    }
    <div class="main-circle">
      <svg>
        <path d="M180,180 v-180 a180,180 0 0,0 -180,180 z" fill="#066a8e">
      </svg>
    </div>

    23.01.2018
  • Да, это другой способ сделать это. Но можете ли вы создать что-то вроде упомянутой ссылки? 24.01.2018
  • Новые материалы

    Освоение информационного поиска: создание интеллектуальных поисковых систем (глава 1)
    Глава 1. Поиск по ключевым словам: основы информационного поиска Справочная глава: «Оценка моделей поиска информации: подробное руководство по показателям производительности » Глава 1: «Поиск..

    Фишинг — Упаковано и зашифровано
    Будучи старшим ИТ-специалистом в небольшой фирме, я могу делать много разных вещей. Одна из этих вещей: специалист по кибербезопасности. Мне нравится это делать, потому что в настоящее время я..

    ВЫ РЕГРЕСС ЭТО?
    Чтобы понять, когда использовать регрессионный анализ, мы должны сначала понять, что именно он делает. Вот простой ответ, который появляется, когда вы используете Google: Регрессионный..

    Не зря же это называют интеллектом
    Стек — C#, Oracle Опыт — 4 года Работа — Разведывательный корпус Мне пора служить Может быть, я немного приукрашиваю себя, но там, где я живу, есть обязательная военная служба на 3..

    LeetCode Проблема 41. Первый пропущенный положительный результат
    LeetCode Проблема 41. Первый пропущенный положительный результат Учитывая несортированный массив целых чисел, найдите наименьшее пропущенное положительное целое число. Пример 1: Input:..

    Расистский и сексистский робот, обученный в Интернете
    Его ИИ основан на предвзятых данных, которые создают предрассудки. Он словно переходит из одного эпизода в другой из серии Черное зеркало , а вместо этого представляет собой хронику..

    Управление состоянием в микрофронтендах
    Стратегии бесперебойного сотрудничества Микро-фронтенды — это быстро растущая тенденция в сфере фронтенда, гарантирующая, что удовольствие не ограничивается исключительно бэкэнд-системами..