<MyRusakov.ru />

Программирование на C++ в Unreal Engine 5

Программирование на C++ в Unreal Engine 5

Данный курс научит Вас созданию игр на C++ в Unreal Engine 5. Курс состоит из 12 разделов, в которых Вас ждёт теория и практика. Причём, в качестве практики будет создан весьма крупный проект объёмом свыше 5000 строк качественного кода, который уже на практике познакомит Вас с принципами создания игр на C++ в Unreal Engine 5.

Параллельно с курсом Вы также будете получать домашние задания, результатом которых станет, в том числе, полноценная серьёзная работа для портфолио.

Помимо самого курса Вас ждёт ещё и очень ценный Бонус: «Тестирование Unreal-проектов на Python», в рамках которого Вы научитесь писать очень полезные тесты для тестирования самых разных аспектов разработки игр.

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

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

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

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

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

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

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

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

Блок с функцией "Read More" на JavaScript

Блок с функцией "Read More" на JavaScript

Функционал "Read More / Read Less" очень часто используется на сайтах, чтобы не перегружать пространство информацией. Пользователь сам решит, какая именно ему информация интересна и нажмет на кнопку "Показать больше".

HTML разметка

Внутри контейнера поместим блок card с иконкой, текстом и ссылкой more.

<div class="container">
  <div class="card">
     <div class="icon">
      <img src="img2.png">
    </div>
    <div class="content">
      <h3>Customer Support</h3>
      <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod
      tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam,
      quis nostrud exgercitation ullamco laboris nisi ut aliquip ex ea commodo
      consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse
      cillum dolore eu fugiat nulla pariatur.</p>
    </div>
    <a class="more"></a>
  </div>
</div>


Блок с функцией Read More на JavaScript.

CSS код

Стилизуем контейнер с карточкой.

@import url('https://fonts.googleapis.com/css?family=Poppins:200,300,400,500,600,700,800,900&display=swap');
*{
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: 'Poppins', sans-serif;
}
body{
    display: flex;/*подключение flexbox*/
    justify-content: center;/*выравнивание по горизонтали*/
    align-items: center;/*выравнивание по вертикали*/
    min-height: 100vh;/*на всю высоту экрана*/
    background: #313131;/*цвет фона*/
}
.container{
    position: relative;/*относительное позиционирование*/
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;/*перенос разрешен на новую строку*/
    width: 1200px;/*ширина контейнера*/
}
.container .card{
    position: relative;
    width: 300px;/*ширина бокса*/
    padding: 20px;/*поля*/
    margin: 20px;/*отступы*/
    background: #3f3f3f;/*фон бокса*/
}


Блок с функцией Read More на JavaScript.

Стилизуем карточку с контентом внутри.

.container .card:before{
    content: '';
    position: absolute;/*абсолютное позиционирование*/
    top: 0;/*верхняя позиция*/
    right: 0;/*правая позиция*/
    border: 20px solid transparent;/*треугольник справа*/
    border-top: 20px solid #17e78c;/*верхняя линия*/
    border-right: 20px solid #17e78c;/*правая линия*/
}

.container .card .icon{
    margin-bottom: 10px;/*промежуток между иконкой и заголовком*/
}
.container .card .icon img{
    max-width: 90px;/*ширина иконки*/
}
.container .card .content{
    position: relative;
    height: 215px;/*текстовый контент занимает высоту 215 пикселей*/
    overflow: hidden;/*остальной текст скрыть*/
}
.container .card h3{
    color: #fff;/*цвет заголовка*/
    font-size: 1.4em;/*шрифт*/
    font-weight: 600;/*толщина шрифта*/
    margin-bottom: 10px;/*отступ снизу*/
}
.container .card p{
    font-weight: 300;
    color: #ccc;/*цвет текста в параграфе*/
}


Блок с функцией Read More на JavaScript.

Создадим кнопку "Read More".

.container .card .more{
    padding: 10px 15px;
    background: #17e78c;
    color: #383838;
    text-transform: uppercase;/*трансформация в маленькие буквы*/
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 2px;/*пространство между буквами*/
    display: inline-block;/*отображать как строчно-блочный*/
    cursor: pointer;
    margin-top: 15px;
}
.container .card .more:before{
    content: 'Read More';/*вывод на кнопке*/
}


Блок с функцией Read More на JavaScript.

Мы полностью стилизовали блок в том виде, в каком его увидит пользователь, зайдя на сайт. Назовем его состояние - не активным.

Активное состояние блока

А что изменится, когда пользователь нажмет на кнопку? Зададим стили для активного блока. В активном состоянии весь текст показывается целиком.

.container .card.active:before{
    border-top: 20px solid #ff3b7e;/*розовый треугольник*/
    border-right: 20px solid #ff3b7e;
}
.container .card.active .content{
    height: auto;/*высота блока определяется автоматически*/
}
.container .card.active .content:before{
    display: none;/*скрыть розовый треугольник*/
}
.container .card.active .more{
    background: #ff3b7e;
    color: #fff;
}
.container .card.active .more:before{
    content: 'Less More';/*вывод на активной кнопке*/
}


Блок с функцией Read More на JavaScript.

Функция на Javascript

Напишем функцию, которая будет переключать наш блок между неактивным (Read More) и активным состояниями (Less More).

//находим элемент more и заносим его в переменную
let more = document.querySelectorAll('.more');
//создание цикла for
    for(let i=0;i<more.length;i++){
//при клике по кнопке запускается функция добавляющая и убирающая активный класс
    more[i].addEventListener("click",function(){
        more[i].parentNode.classList.toggle("active");
    })
}

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

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

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

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

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

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

  1. Кнопка:

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

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

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

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

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

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