Можно ли это сделать с помощью кода? Совершенно верно.
Обратите внимание, что StackOverflow не является домом кодирования. Мы не можем написать весь этот код для вас, поэтому самое большее, что вы должны ожидать от этих ответов, - это хорошее начало в правильном направлении.
Вы спрашивали конкретно о PHP и Javascript, но я тоже добавлю туда HTML. Давайте посмотрим на каждого.
PHP
Сделайте быстрый поиск для 3D-рендеринга в PHP. Вы не найдете много, потому что не так много. На стороне сервера существуют далеко улучшенные языки, движки и библиотеки, разработанные специально для 3D-рендеринга.
Хорошей альтернативой этому являются языки, которые большинство разработчиков игр используют для моделирования персонажей и рендеринга, которые часто включают в себя C ++, Java и Python (этот еще больше для логики и иногда движения).
Javascript / jQuery
Существует несколько приличных игровых движков javascript, способных обрабатывать 3D-рендеринг. Обратите внимание, что они часто не предназначены для моделирования персонажей, поскольку они ожидают, что большая часть этой работы будет выполняться вне самого движка. Обычно это библиотека, используемая совместно с WebGL. Вот два популярных варианта:
https://www.babylonjs.com
https://threejs.org
HTML Canvas
Это возможно здесь, но требует больше кода, чем использование движка, предназначенного для этой работы.
Вот пример игры с HTML: https://www.html5rocks.com/en/gaming/
Вот куб в HTML5 canvas и WebGL: https://www.webcodegeeks.com/html5/html5-3d-canvas-tutorial/
Обратите внимание, сколько кода и усилий требуется для воспроизведения простого куба. Вам нужно будет учитывать внешнюю форму рубашки, изгиб ткани вокруг этих фигур (не только следуя за краями, но следуя реалистичным изгибам на деталях, таких как изогнутая рука), впечатление глубины для частей рубашки которые ближе и дальше, и искривление ткани по морщинам в рубашке. Эти детали требуют НЕМНОГО количества кодирования.
Стоит ли тратить ваше личное время и усилия? Вероятно, нет.
- Возврат инвестиций за потраченное время будет низким. Вы потратите много времени и ресурсов, чтобы заставить это работать хорошо.
- Если это делается на стороне клиента (html или js), включенный код и библиотеки будут больше, чем клиенты должны иметь дело с загрузкой для чего-то меньшего, чем игровые цели.
- Запуск этого кода каждый раз при переключении структуры будет трудоемким на стороне клиента.
- Существуют лучшие варианты (требующие меньшего количества кода и меньшей вычислительной мощности), которые достигают той же цели, например, как это сделали Бомбейские рубашки в демоверсии.
Как Бомбейские Рубашки делают это?
Ниже приведена фотография открытого инспектора, просматривающего ресурсы страницы. В красной рамке слева находится список всех частей рубашки. Выбран один, который вы видите на картинке справа.
Все изображенные компоненты рубашки имеют тип файла .pfs . Файлы PFS являются собственностью PhotoFiltre Studio . PhotoFiltre Studio выполняет редактирование изображений, но также помогает устанавливать координаты между элементами.
Существует около 11 отдельных изображений для манжет, воротников, пуговиц, карманов и рукавов. интересно то, что компоненты рубашки не имеют 2D вида: детали, которые не видны при окончательном рендеринге, видны здесь (например, внутренняя часть отверстий втулки, как показано выше). Это связано с тем, что каждый компонент рубашки, скорее всего, был сделан с помощью какого-либо программного обеспечения для 3D-моделирования.
Реальный ответ, однако, заключается в том, что Бомбейские рубашки вообще этого не сделали. Если вы внимательно посмотрите, откуда поступают изображения, это другой сервер, чем у них в целом:
<img class="img-fluid" src="https://bombayshirts.picarioxpo.com/collar_prince_charlie_v00.pfs?1=1&width=500&p.tn=BB001A.jpg&p.tr=True" alt="custom shirts" style="z-index: 2;">
Эти изображения получены на picarioxpo.com.Это веб-сайт Picario , компании, которая специализируется на создании настраиваемых 3D-визуализаций продуктов.
Решения
Использование существующих решений ←Выберите этот!
Бомбейские рубашки никогда бы не пошли с ручными решениями ниже, потому что слишком много тканей и вариантов - это заняло бы слишком много времени.Вместо того, чтобы изобретать велосипед, они выбрали решение Picario. Вы можете сделать то же самое.
Преимущества:
- нет хардкорного кодирования и знаний
- нет хардкорных фотосессий и навыков
- нет хардкорного 3D моделирования и бесконечного экспорта
- нет вычислительной мощности на стороне клиента или используемой полосы пропускания
- быстро / легко реализуемо
Пара вариантов:
Picario XPO
iDesigniBuy Программное обеспечение для пошива одежды
Программное обеспечение для 3D моделирования
- Используйте программное обеспечение для 3D-моделирования, чтобы создать модель вашего продукта.Если у вас есть продукты с видимыми опциями, создайте одну модель для каждого компонента рубашки.Я рекомендую Blender , потому что он бесплатный, довольно качественный и хорошо документированный. Maya , возможно, лучше, но это не бесплатно.
- Сохраните каждую ткань как материал / текстуру (здесь я мог бы перепутать терминологию) и примените каждую к вашей модели..
- Экспорт одинакового вида спереди каждой модели / компонента с нанесенной тканью (например: https://blender.stackexchange.com/questions/39022/how-to-save-render).
- Когда пользователь запрашивает ваш продукт из браузера, отправьтекаждый завершенный компонент в браузере с координатами, указывающими, где его найти, чтобы выровнять его с другими компонентами.
Вручную с кодом / Photoshop
Практически любое другое решение потребует слишком много времени / знаний / денег - особенно если идти по пути ручного кодирования этой функции с помощью алгоритмов. Фотосъемка каждого изображения была бы интенсивной работой с очень противоречивыми результатами (если вы не гений фотошопа).
У Криса Луенго был большой вопрос в комментариях:
Почему отдельное изображение для каждого компонентарубашки?Разве не было бы проще иметь изображение для каждой цельной рубашки?- Крис Луенго
Ответ на этот вопрос:
@ CrisLuengo большой вопрос.Это потому, что некоторые рубашки имеют разные карманы, пуговицы, стили воротника и т. Д. Вы можете либо иметь совершенно отдельную модель для всех них, либо использовать одинаковые базовые модели и просто обновить компоненты.Это та же причина, по которой мы используем код многократного использования: более низкое обслуживание.
Я понимаю, что этот и другие ответы не соответствуют вашим ожиданиям надеялись для, но они, безусловно, посылают последовательное сообщение о том, что PHP / JS / HTML не являются подходящими инструментами для работы.