<MyRusakov.ru />

Разработчик игр на Unreal Engine

Разработчик игр на Unreal Engine

Этот комплект с нуля всего за 7 месяцев сделает Вас Unreal-разработчиком. И при этом учиться достаточно 1 час в день.

Начнёте Вы с основ программирования, постепенно перейдя к C++. Затем очень подробно изучите Unreal Engine, и после научитесь программировать на C++ в Unreal Engine. В конце создадите крупный проект на C++ в Unreal Engine для своего портфолио.

Комплект содержит:

- 416 видеоуроков

- 95 часов видео

- 1024 задания для закрепления материала из уроков

- 3 финальных тестирования

- 4 сертификата

- 12 Бонусных курсов

Подробнее
Подписка

Подпишитесь на мой канал на YouTube, где я регулярно публикую новые видео.

YouTube Подписаться

Подписавшись по E-mail, Вы будете получать уведомления о новых статьях.

Подписка Подписаться

Добавляйтесь ко мне в друзья ВКонтакте! Отзывы о сайте и обо мне оставляйте в моей группе.

Мой аккаунт Мой аккаунт Моя группа
Опрос

Какая тема Вас интересует больше?

SVG hover эффект для кнопки

SVG hover эффект для кнопки

Формат SVG дает новые возможности для рисования различных фигур и анимирования их. Сегодня мы рассмотрим SVG hover эффект на кнопку. Создадим внешний контейнер с классом button и внутри него поместим тег svg. Внутри парного тега svg будет располагаться тег rest, изображающий прямоугольник без заливки и с позиционированием от верхнего левого угла браузера.

<div class="button">
    Hover Me
    <svg width="150" height="75" viewBox="0 0 150 75" xmlns="http://www.w3.org/2000/svg">
        <rect x='0' y='0' fill='none' width='150' height='75'/>
    </svg>
</div>

//CSS
body {
    background-color: #F5F5F5; /* цвет фона страницы */
    font-family: sans-serif; /* название шрифта */
}

Стилизация кнопки

.button {
    text-transform: uppercase; /* текст заглавными буквами */
    width: 150px; /* ширина кнопки */
    height: 75px; /* высота кнопки */
    color: #bf360c; /* цвет текста */
    text-align: center; /* текст по центру по горизонтали */
    line-height: 75px; /* текст по центру по вертикали */
    margin: 20px auto; /* внешние отступы у кнопки */
    position: relative; /* относительное позиционирование */
    cursor: pointer; /* курсор рука */
}


SVG hover эффект для кнопки.

SVG располагает большим арсеналом CSS свойств, отвечающих за стиль контуров.

svg {
    position: absolute; position: relative; /* абсолютное позиционирование */
    top: 0; /* привязка к верхнему углу */
    left: 0; /* привязка к левому углу */
}

svg rect {
    stroke: #bf360c; /* цвет контура прямоугольника */
    stroke-width: 2; /* ширина контура прямоугольника */
    transition: 0.8s; /* плавный переход между состояниями */
}


SVG hover эффект для кнопки.

Эффект наведения

Переходим к самому главному. Мы хотим, чтобы при наведении на кнопку, увеличивалась ширина контуров прямоугольника. Кроме того, сплошной контур линии должен меняться на прерывистую линию. За это отвечает свойство stroke-dasharray. Первым параметром данного свойства мы указываем ширину линии, а вторым параметром промежуток между линиями.

svg rect {
    stroke-dasharray: 20, 40;
}


SVG hover эффект для кнопки.

Зададим изначально максимально длинную линию с нулевым промежутком у свойства stroke-dasharray.

svg rect {
    stroke: #bf360c;
    stroke-width: 2;
    transition: 0.8s;
    stroke-dasharray: 400, 0; /* эффект сплошной линии */
}

При наведении на кнопку вместо сплошной линии появляется пунктирная линия.

.button:hover svg rect {
    stroke-width: 5;
    stroke-dasharray: 35, 275; /* пунктир и промежуток */
    stroke-dashoffset: 40; /* смещение пунктира */
}


SVG hover эффект для кнопки.

Посмотрите пример на CodePen

Мир фронтенда очень велик и разнообразен и как не утонуть в потоке информации? И с чего вообще начать? Я рекомендую идти от простого к сложному и последовательно изучить все базовые возможности HTML и CSS, по моему видеокурсу "Верстка сайта с нуля 2.0".

Копирование материалов разрешается только с указанием автора (Михаил Русаков) и индексируемой прямой ссылкой на сайт (http://myrusakov.ru)!

Добавляйтесь ко мне в друзья ВКонтакте: http://vk.com/myrusakov.
Если Вы хотите дать оценку мне и моей работе, то напишите её в моей группе: http://vk.com/rusakovmy.

Если Вы не хотите пропустить новые материалы на сайте,
то Вы можете подписаться на обновления: Подписаться на обновления

Если у Вас остались какие-либо вопросы, либо у Вас есть желание высказаться по поводу этой статьи, то Вы можете оставить свой комментарий внизу страницы.

Порекомендуйте эту статью друзьям:

Если Вам понравился сайт, то разместите ссылку на него (у себя на сайте, на форуме, в контакте):

  1. Кнопка:

    Она выглядит вот так: Как создать свой сайт

  2. Текстовая ссылка:

    Она выглядит вот так: Как создать свой сайт

  3. BB-код ссылки для форумов (например, можете поставить её в подписи):

Комментарии (0):

Для добавления комментариев надо войти в систему.
Если Вы ещё не зарегистрированы на сайте, то сначала зарегистрируйтесь.