Форум программистов, компьютерный форум, киберфорум
JavaScript: HTML5 Canvas
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
43 / 3 / 3
Регистрация: 02.09.2017
Сообщений: 217

Код обхода препятствий?

19.02.2023, 22:01. Показов 1647. Ответов 6
Метки js (Все метки)

Студворк — интернет-сервис помощи студентам
Делаю карту. Сделал тайлы, - стены. И пока речь идет об 1 тайле и 1 коллизии - все нормально, то есть персонаж под углом подходит к стене, допустим и движется вдоль к щелчку мыши за стеной. Но 2 тайла впритык уже все стопорится. Если из них сделать стены и стены перегородки между 2 комнатами, то вообще ничего не работает.
тайл сделан как массив.
То есть нужно, чтобы персонаж подходил к любой из 4 стен и двигался сохраняя, ту скорость, вектор движения которой не ограничен.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
19.02.2023, 22:01
Ответы с готовыми решениями:

Формирование пути между точками а и б с учетом обхода препятствий
Здравствуйте. Собственно полностью это звучит следующим образом: "Реализовать возможность отметить на карте 2 точки А и Б с последующим...

Простая нейронная сеть для обхода препятствий (C# + Unity3d)
Всем привет, хочется написать простую нейронную сеть для обхода объектом препятствий. То есть есть плоскость ( XZ ) вдоль которой в...

Код обхода графа
Ситуация такая! Есть StringGrid! В нем строки и столбцы это одни и теже объекты (т.е StringGrid1->Cells="O1";...

6
9933 / 2936 / 494
Регистрация: 05.10.2013
Сообщений: 7,978
Записей в блоге: 235
20.02.2023, 19:05
Скорее всего, вы хотите написать своё решение без физических движков. Но напишу на будущее на чём может быть проще и быстрее решать некоторые задачи (детектирование столкновений, raycasting, физика и т.д.). В игровых движках типа Unity и Godot задачи с столкновениями решаются с помощь встроенных физических движков. Например, для 2D в Unity и Gogot встроен Box2D, а для 3D - PhysX и Bullet Physics.

Есть порты Box2D на JavaScript и TypeScript, например:
  • box2d-wasm - прямая сборка Box2В в WASM с помощью Emscripten
  • @box2d/core - переписанный Box2D на JS и TS
  • planck.js - переписанный Box2D на JS и TS

Есть самостоятельные физические движки, то есть не порты Box2D:
Пример подключения Matter.js с помощью importmap с размещением в песочницах PlayCode и Plunker, где возможно создавать примеры с несколькими файлами:

index.html

PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
<!DOCTYPE html>
 
<html lang="en">
 
<head>
    <meta charset="UTF-8">
    <title>Example</title>
</head>
 
<body style="caret-color: transparent;">
    <canvas id="renderCanvas" width="400" height="400"></canvas>
 
    <!-- Since import maps are not yet supported by all browsers, it is
        necessary to add the polyfill es-module-shims.js
        Source: https://threejs.org/docs/index.html#manual/en/introduction/Installation -->
    <script async src="https://unpkg.com/es-module-shims@1.3.6/dist/es-module-shims.js"></script>
    <script type="importmap">
        {
            "imports": {
                "gl-matrix": "https://cdn.jsdelivr.net/npm/gl-matrix@3.4.3/+esm",
                "matter-js": "https://cdn.jsdelivr.net/npm/matter-js@0.19.0/+esm"
            }
        }
    </script>
 
    <script type="module" src="js/main.js"></script>
</body>
 
</html>
js/main.js

JavaScript
1
2
3
4
import { mat4, vec3 } from "gl-matrix";
import { default as Matter } from "matter-js";
 
console.log(`Matter.js version: ${Matter.version}`);
2
43 / 3 / 3
Регистрация: 02.09.2017
Сообщений: 217
20.02.2023, 20:39  [ТС]
Спасибо, буду изучать.
Был уверен, что Box2D это для гравитации, платформеров и т.д. А у меня вид сверху.
0
9933 / 2936 / 494
Регистрация: 05.10.2013
Сообщений: 7,978
Записей в блоге: 235
30.03.2023, 00:02
У Planck.js отличное руководство. Разработчики Planck.js просто переделали официальное руководство Box2D. Но у Planck.js есть огромный недостаток - отсутствует рисование коллайдеров, то есть класс b2Draw не был переписан на JS. Зато есть много официальных примеров: https://piqnt.com/planck.js/8-Ball Их туториалы и примеры можно использовать в других портах Box2D на JS.

Есть такой порт под названием box2d-wasm, а точнее это сборка Box2D из C++ в WebAssembly (WASM) с помощью Emscripten. Так вот, в box2d-wasm я обнаружил очень неприятный баг: RayCast doesn't work in my simple example, то есть не работает посылание луча. Но всё-таки скину рабочий пример с падающим квадратом, может потом решат:



Миниатюры
Вложения
Тип файла: zip debug-drawer-box2dwasm-js.zip (6.3 Кб, 0 просмотров)
1
9933 / 2936 / 494
Регистрация: 05.10.2013
Сообщений: 7,978
Записей в блоге: 235
30.03.2023, 00:13
Пока что лучшей порт, который я находил - это box2d-core. У него есть небольшая проблема с рисованием коллайдеров - это сдвиг поворота коллайдера на несколько градусов, но это некритично.



Миниатюры
Вложения
Тип файла: zip collider-angle-offset-problem-box2dcore-js.zip (6.6 Кб, 2 просмотров)
1
9933 / 2936 / 494
Регистрация: 05.10.2013
Сообщений: 7,978
Записей в блоге: 235
30.03.2023, 00:20
Цитата Сообщение от 8Observer8 Посмотреть сообщение
У Planck.js отличное руководство. Разработчики Planck.js просто переделали официальное руководство Box2D. Но у Planck.js есть огромный недостаток - отсутствует рисование коллайдеров, то есть класс b2Draw не был переписан на JS. Зато есть много официальных примеров: https://piqnt.com/planck.js/8-Ball Их туториалы и примеры можно использовать в других портах Box2D на JS.
Это руководство находится на Wiki разделе их репозитория: https://github.com/shakiba/planck.js/wiki
0
43 / 3 / 3
Регистрация: 02.09.2017
Сообщений: 217
30.03.2023, 18:31  [ТС]
Спасибо, почитаю. Пока игру (геймдизайн) переделал.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
30.03.2023, 18:31
Помогаю со студенческими работами здесь

Изменить код для обхода антиплагиата
Здравствуйте, система антиплагиата ругается и не хочет принимать данный код. Помогите пожалуйста его изменить, смысл работы программы...

Исправить код обхода двумерного массива
Добрый день! есть массив 6х6 заполненный рандомными числами от 10 до 100 движение в массиве начинается с нижней левой точки и идет...

Код в maple обхода дерева в прямом порядке
Подскажите пожалуйста алгоритм списка узлов при обходе в прямом порядке?Нужно реализовать в maple Дерево построил, присвоил каждому узлу...

Написать код обхода выделенной области матрицы
Здравствуйте. Задача такая: в квадратной матрице порядка n задана область(выделена на рисунке). Написать цикл обхода заштрихованной...

Нужно переделать код из индексного обхода в итераторный
#include &quot;pch.h&quot; #include &lt;iostream&gt; #include &lt;fstream&gt; using namespace std; int main() { setlocale(LC_ALL, &quot;Russian&quot; ); ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&amp;d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru