3 Commits

Author SHA1 Message Date
42be04def9 feat(week4): модальные сцены, кастомные скины игрока и вики-гайды по 4 играм
Some checks failed
CI / Lint (pull_request) Failing after 1m10s
CI / Build (pull_request) Successful in 2m2s
CI / Secret scan (pull_request) Successful in 2m36s
CI / PR size check (pull_request) Successful in 6s
CI / Deploy to S1 + S2 (pull_request) Has been skipped
Задача 04 — модальные сцены (затемнение + GUI/3D-анимация + блок ввода):
- engine/ModalManager.js (state-машина, fade, spotlight-проекция, HighlightLayer)
- editor/ModalOverlay.jsx (CSS-overlay + mask-image для spotlight)
- PlayerController.setInputBlocked/setCameraFrozen/captureCameraState/focusOnTarget
- game.modal.open/close/update/isOpen/onClose + пресеты bossIntro/lootbox/dialog/confirmation
- Фиксы ядра: клик GUI-кнопок (realId↔localId), modalOpened через globalEvent,
  guard от двойного срабатывания колбэков, кнопка ✓ на последней строке диалога

Задача 07 — кастомные скины игрока + магазин:
- non-humanoid скины (любая 3D-модель): загрузчик, процедурная анимация,
  настраиваемый AABB, центрирование через pivot-node
- PlayerController.reloadSkin (смена скина в Play)
- game.player.setSkin/unlockSkin/getAvailableSkins/onSkinChange/openSkinShop + локальная валюта
- editor/SkinShopOverlay.jsx (встроенный магазин, клавиша B) + SkinManagerModal.jsx (вкладка «Скины»)
- сериализация scene.skins, кнопка «Скины» в тулбаре

Вики — категория «Разбор готовых игр»:
- docsGames.js: группа g5 + 4 карточки (Двор/Витрина GUI/Сундук/Парк)
- docsLessons.jsx: 4 подробные статьи-урока для детей
- «Открыть мою копию» создаёт копию проекта (оригинал не трогается)

Адаптивная ширина кнопки billboard под длинный текст.

Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
2026-05-30 00:50:56 +03:00
d6cc986aa9 fix(billboard+autosave+spawn): зеркало текста, защита от перезаписи, шорткаты
Some checks failed
CI / Lint (pull_request) Failing after 7s
CI / PR size check (pull_request) Successful in 19s
CI / Secret scan (pull_request) Successful in 2m46s
CI / Build (pull_request) Successful in 2m54s
CI / Deploy to S1 + S2 (pull_request) Has been skipped
1) Билборд (Магазин апгрейдов, ID=1906): текст и иконки отрисовывались
   зеркально из-за того что BILLBOARDMODE_ALL разворачивает FRONT-сторону
   plane так что мы видим back-side с зеркальным UV. mesh.scaling.x=-1
   игнорируется billboardMode. Решение: отключить billboardMode, вместо
   него каждый кадр в onBeforeRenderObservable ставим mesh.rotation.y =
   atan2(dx,dz) + PI — front смотрит на камеру → UV рисуется правильно.

2) Autosave перезаписывал реальный проект пустой стартовой сценой при
   reload страницы (баг #1893, #1905 — оба перетёрты). Добавил
   sceneLoadingRef guard в doSave: пока sceneLoading=true, autosave
   запрещён.

3) Запрет публикации без обложки — фронт (alert + open Settings) и бэк
   (400 thumbnail_required если pd.thumbnail < 100 байт).

4) Scripting API:
   - шорткат: game.scene.spawn('billboard',...) вместо
     'primitive:billboard' (применяется ко всем примитивам)
   - проброс template/face/content/elements в scene.spawn для билбордов
   - PrimitiveManager.updateInstance — поддержка billboardOpts patch'а

5) Тест-игра 'Магазин апгрейдов' ID=1906 — 4 shop-item билборда +
   banner + shop-purchase кнопка 'Сбросить апгрейды' + HUD рубликов.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-29 13:38:09 +03:00
c32914c819 feat: интерактивные 3D-таблички (BillboardGui/SurfaceGui)
Some checks failed
CI / PR size check (pull_request) Successful in 22s
CI / Lint (pull_request) Failing after 2m17s
CI / Secret scan (pull_request) Successful in 3m21s
CI / Build (pull_request) Successful in 3m31s
CI / Deploy to S1 + S2 (pull_request) Has been skipped
Задача 01 из 1 - Неделя 4/ЗАДАЧИ РУБЛОКС. P0-приоритет: без таблиц
с кнопками невозможны симуляторы, тайкуны, фермы.

Новое:
- engine/BillboardUiManager.js — 4 пресета (shop-item, shop-purchase,
  banner, sign), 18 иконок, DynamicTexture-рендер, UV-hit-test
- PrimitiveTypes: новый тип 'billboard' в категории 'gameplay'
- PrimitiveManager: case billboard в _createMeshForType (Plane), init
  через applyToMesh, billboardOpts в updateInstance
- BabylonScene: PointerEventTypes-handler для кликов с _isPlaying-чеком
  и pointer-lock поддержкой
- GameRuntime: команды billboard.set/update/onClick, callback через
  sandbox.sendEvent('billboardClick')
- ScriptSandboxWorker: пространство game.billboard.{set,update,onClick}
- BillboardEditorModal.jsx — модалка с живым canvas-превью, 8 готовых
  градиентов + кастомные пикеры, дропдаун из 18 иконок
- InspectorPanel: кнопка 'Редактировать табличку…' для billboard-примитива
- KubikonEditor: проброс модалки через onEditBillboard prop
- Icon.jsx: SVG prim-billboard

Два режима ориентации: 'camera' (BillboardGui-аналог, всегда смотрит
на игрока) и 'fixed' (SurfaceGui-аналог, прикреплён к поверхности).

Клик-детекция через ray-pick → UV → пиксели текстуры → поиск кнопки
по AABB; работает с пиксельной точностью даже при повороте камеры.

Документация: RUBLOX_STUDIO_FUNCTIONS.md раздел 1.25.

Тестовая игра 'Магазин апгрейдов' (4 таблички + банер + HUD) — МИН
соберёт в студии drag-n-drop'ом.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-29 11:58:06 +03:00