Привет, Хабр! Представляю вашему вниманию перевод статьи Building a 3D Game with CSS + HTML автора Michael Bromley.
Не так давно я изучал редко используемые функции CSS — функцию анимации и 3D, а после общения в конференции по JavaScript я собрал вот это demo. Пока я трудился над ним, мне стало любопытно, как далеко можно зайти в конструировании трёхмерной графики на чистом CSS.
(скриншот выполнен переводчиком)
В какой-то момент я наткнулся на работы Кейта Кларка (Keith Clark). Он собрал два замечательных примера на CSS: один из них — основа для 3D FPS-шутера от первого лица (в стиле Counter-Strike. прим. переводчика), второй — модель звёздного истребителя X-Wing с использованием теней:
(скриншот выполнен переводчиком)
Вдохновлённый его работами и образцами на Codеpen, я решил попробовать сделать звёздный 3D-шутер на чистом CSS и HTML, но, конечно, с добавлением JavaScript. То есть, чтобы отрисовать все объекты игры, я использовал только CSS и HTML. Иными словами, игра разрабатывалась без использования изображений, WebGl, canvas или векторной графики (SVG). Результат можно посмотреть и потестировать по данной ссылке.
Поскольку этой работой я хотел подчеркнуть возможности CSS, я остановился именно на олдскульной космической стрелялке: когда движешься вглубь экрана, а вражеские корабли летят на тебя. Что ещё нужно, чтобы получить эффект 3D?
Схематичный дизайн объектов и цветовая палитра навеяны старой игрой Tempest. для компьютера Atari. Этот стиль позволяет не заботиться о добавлении теней.
Хороший вопрос. Был ли CSS разработан для подобных вещей? Однозначно, нет. Я лишь хотел показать каким мощным средством может быть CSS.
Результат у автора получился неплохой, в эту игру действительно можно поиграть, по крайне мере пару минут. Я не стал переводить всю статью. Далее автор пишет о преимуществах CSS для разработки 3D, а также о проблемах, с которыми столкнулся. Смыл сводится к тому, что не стоит использовать CSS для разработки игр, особенно трёхмерных.
На мой взгляд, идея реализации трёхмерного пространства на CSS и HTML приобретает смысл,
когда стоит задача разработки проекта с неполной 3D-графикой, т.е. когда часть пространства или объекты могут быть реализованы благодаря некоторым трюкам, например, с перспективой.
В целом, современные 3D-игры, наполненные обилием эффектов, — в сравнении с проектами 20-летней давности — кажутся перегруженными. Стремление к натуралистичным эффектам отводит игрока от самой игры (я имею в виду спортивный азарт, желание пройти саму игру, в противовес наблюдению эффектных взрывов и салютов), поэтому мне все чаще и чаще вспоминаются 2.5D игры с объектами из спрайтов, некоторые из которых, вероятно, можно попытаться переложить, используя веб-технологии. Может быть, некоторые игры для консолей 90-х годов (кстати, для приставки Sega существовали вполне настоящие трехмерные игры. Примечание для молодого поколения).
К желанию немного разобраться в данной теме меня привело чтение некоторых публикаций на Хабрахабре (и не только) по линейной алгебре, а также стремление понять, как изнутри устроены 3D-преобразования. После чтения статей, что приведены ниже, у меня даже появилось желание создать какую-нибудь простенькую игру на CSS, на тему космоса (с минимальным количеством 3d-преобразований и каким-нибудь трюками, заменяющими «реальное» 3D ), но через некоторое время я нашел данный блог, где уже было сделано почти то, что я хотел сделать. Должен заметить, что очень удобно использовать крайне удалённые объекты для формирования пространства. К таким объектам фактически не нужно применять линейные преобразования, а зрительный эффект даже интереснее (например, если фоном сделать фотографию космоса и возможность вращения по одной оси), нежели 3D-стены с фрактальными текстурами, как в современных играх… В общем, многие старые игрушки вполне можно воскресить для новых поколений.
Не так давно я изучал редко используемые функции CSS — функцию анимации и 3D, а после общения в конференции по JavaScript я собрал вот это demo. Пока я трудился над ним, мне стало любопытно, как далеко можно зайти в конструировании трёхмерной графики на чистом CSS.
(скриншот выполнен переводчиком)
В какой-то момент я наткнулся на работы Кейта Кларка (Keith Clark). Он собрал два замечательных примера на CSS: один из них — основа для 3D FPS-шутера от первого лица (в стиле Counter-Strike. прим. переводчика), второй — модель звёздного истребителя X-Wing с использованием теней:
(скриншот выполнен переводчиком)
Вдохновлённый его работами и образцами на Codеpen, я решил попробовать сделать звёздный 3D-шутер на чистом CSS и HTML, но, конечно, с добавлением JavaScript. То есть, чтобы отрисовать все объекты игры, я использовал только CSS и HTML. Иными словами, игра разрабатывалась без использования изображений, WebGl, canvas или векторной графики (SVG). Результат можно посмотреть и потестировать по данной ссылке.
Поскольку этой работой я хотел подчеркнуть возможности CSS, я остановился именно на олдскульной космической стрелялке: когда движешься вглубь экрана, а вражеские корабли летят на тебя. Что ещё нужно, чтобы получить эффект 3D?
Схематичный дизайн объектов и цветовая палитра навеяны старой игрой Tempest. для компьютера Atari. Этот стиль позволяет не заботиться о добавлении теней.
Почему CSS?
Хороший вопрос. Был ли CSS разработан для подобных вещей? Однозначно, нет. Я лишь хотел показать каким мощным средством может быть CSS.
Мнение переводчика
Результат у автора получился неплохой, в эту игру действительно можно поиграть, по крайне мере пару минут. Я не стал переводить всю статью. Далее автор пишет о преимуществах CSS для разработки 3D, а также о проблемах, с которыми столкнулся. Смыл сводится к тому, что не стоит использовать CSS для разработки игр, особенно трёхмерных.
Вместо заключения. Мысли переводчика
На мой взгляд, идея реализации трёхмерного пространства на CSS и HTML приобретает смысл,
когда стоит задача разработки проекта с неполной 3D-графикой, т.е. когда часть пространства или объекты могут быть реализованы благодаря некоторым трюкам, например, с перспективой.
В целом, современные 3D-игры, наполненные обилием эффектов, — в сравнении с проектами 20-летней давности — кажутся перегруженными. Стремление к натуралистичным эффектам отводит игрока от самой игры (я имею в виду спортивный азарт, желание пройти саму игру, в противовес наблюдению эффектных взрывов и салютов), поэтому мне все чаще и чаще вспоминаются 2.5D игры с объектами из спрайтов, некоторые из которых, вероятно, можно попытаться переложить, используя веб-технологии. Может быть, некоторые игры для консолей 90-х годов (кстати, для приставки Sega существовали вполне настоящие трехмерные игры. Примечание для молодого поколения).
К желанию немного разобраться в данной теме меня привело чтение некоторых публикаций на Хабрахабре (и не только) по линейной алгебре, а также стремление понять, как изнутри устроены 3D-преобразования. После чтения статей, что приведены ниже, у меня даже появилось желание создать какую-нибудь простенькую игру на CSS, на тему космоса (с минимальным количеством 3d-преобразований и каким-нибудь трюками, заменяющими «реальное» 3D ), но через некоторое время я нашел данный блог, где уже было сделано почти то, что я хотел сделать. Должен заметить, что очень удобно использовать крайне удалённые объекты для формирования пространства. К таким объектам фактически не нужно применять линейные преобразования, а зрительный эффект даже интереснее (например, если фоном сделать фотографию космоса и возможность вращения по одной оси), нежели 3D-стены с фрактальными текстурами, как в современных играх… В общем, многие старые игрушки вполне можно воскресить для новых поколений.
Ссылки
- 3D-трансформации средствами CSS
- Линейная алгебра для разработчиков игр
- Краткий курс компьютерной графики: пишем упрощённый OpenGL своими руками, статья 4a из 6
- Затерянная документация или transform: matrix3d
- Создаём собственный программный 3D-движок
- learnopengl. Урок 1.7 — Трансформации
- Tridiv: редактор 3D CSS
Комментарии (9)
izzholtik
17.11.2017 12:20Добавьте опцию инвертирования управления.
oisee
17.11.2017 17:48+1Да, переводчик, ты же всё равно статью недоперевёл. Хотя-бы добавь тогда инвертированное управление.
dcc0 Автор
17.11.2017 23:41Зачем инвертирование?
Начните уже кто-нибудь Zero Tolerance для веб портировать…
и чтобы мультиплеер был: ), 10на10 как в CS. И чтобы можно было регистрироваться + чат, сохранение настроек и очков игры.
retran
17.11.2017 17:36+1Игра на Atari называлась не Tempset, а Tempest.
А для сеги было и вполне настоящее 3D — ru.wikipedia.org/wiki/Virtua_Racing
Flakky
Это все интересно, конечно, но совсем не практично, учитывая что есть Canvas и WebGL, которые быстрее, удобнее, еще и поддерживаются лучше.
demimurych
Есть один очень интересный момент о котором стоит подумать — игра, написанная при помощи css и html может индексироваться поисковиками.
fatronix
Нет, думать об этом не стоит. Что там будет индексироваться? Миллион пустых div?
demimurych
Попробуйте посмотреть шире. Например сайт, где получение информации происходит в игровой форме. Например для детей, или людей с особыми потребностями. И там уже, будет не просто миллион пустых дивов.
Flakky
Игры — одностраничные приложения, в которых все данные динамические. Индексация хоть и будет, но какая? Первоначальная, где есть только кнопочка «Начать игру»?
Если уж и задумываться о СЕО тут, то логичнее сделать отдельную страницу/блог по игре, где есть вся инфа, медиа, форумы и прочее… Это полезнее, чем сама страница игры с точки зрения поисковика и даже самого пользователя, который захочет вначале узнать о проекте.