如何在A-Frame中添加导航路径?
我尝试了各种 A 形框架的方法,但是,我无法找到一个好的方法来制作一条路径,使头像无法走出该路径,也无法穿过场景中存在的墙壁和物体。我尝试使用搅拌机制作自己的导航网格,但也许我错过了一些东西。
所以请帮我解决 A-Frame 中的问题!!
<a-scene
inspector-plugin-recast
renderer="antialias: true;
colorManagement: true;
sortObjects: true;
physicallyCorrectLights: true;
highRefreshRate: true;"
>
<a-assets>
<a-asset-item id="rig" src="./navmesh.gltf"></a-asset-item>
</a-assets>
<a-entity
id="rig"
movement-controls="speed:0.15; constrainToNavMesh: true"
position="0 0 5"
>
<a-entity
camera
position="0 1.6 0"
look-controls="pointerLockEnabled: true"
>
<a-cursor nav-pointer raycaster="objects: [nav-mesh]"></a-cursor>
</a-entity>
</a-entity>
<a-entity gltf-model="#rig" nav-mesh visible="false"></a-entity>
</a-scene>
navmesh.gltf 是为相机提供导航路径,以便相机无法超出此网格。我使用生成的这个 gltf
aframe-inspector-plugin-recast.js。
所以,它可以工作,但是当我制作自己的导航网格并添加它时,要么浏览器没有加载场景,要么我的相机总是在场景之外。
I tried various ways A-Frame but, I can't able to get a good way to make a path so that avatar can't go outside that and also can't pass through walls and objects which are there in the scene. I tried to make my own navmesh using blender but maybe I'm missing something.
So please help me regarding this in A-Frame !!
<a-scene
inspector-plugin-recast
renderer="antialias: true;
colorManagement: true;
sortObjects: true;
physicallyCorrectLights: true;
highRefreshRate: true;"
>
<a-assets>
<a-asset-item id="rig" src="./navmesh.gltf"></a-asset-item>
</a-assets>
<a-entity
id="rig"
movement-controls="speed:0.15; constrainToNavMesh: true"
position="0 0 5"
>
<a-entity
camera
position="0 1.6 0"
look-controls="pointerLockEnabled: true"
>
<a-cursor nav-pointer raycaster="objects: [nav-mesh]"></a-cursor>
</a-entity>
</a-entity>
<a-entity gltf-model="#rig" nav-mesh visible="false"></a-entity>
</a-scene>
navmesh.gltf is to give the navigation path to the camera so that is could not go outside this mesh. This gltf i've generated by using
aframe-inspector-plugin-recast.js.
So, it's working but when I'm making my own navmesh and adding it then, either browser didn't load the scene or my camera always goes outside it.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
这是关于 navmesh 概念的很好的教程:
https://www.youtube.com/watch?v=Y52czIft9OU
其他非更简单的创建类似于 navmesh 的系统的方法是使用 Ammo.js 等物理系统,该系统广泛用于 AR/VR 游戏开发。
您基本上会在竞技场周围创建墙壁,以便化身不会超出它。您可以设置 ammo-body 将墙壁设为静态,将头像设为动态。
虽然碰撞逻辑需要一个 collider,但有您可以研究并测试许多不同的方法,找出最适合您的方法。
This is a good tutorial on the concept of navmesh:
https://www.youtube.com/watch?v=Y52czIft9OU
Other non simpler ways to create a system similar to navmesh is by using physics systems like Ammo.js which is used widely for game development in AR/VR.
You would basically create walls around your arena so that the avatar does not go beyond it. You can set the ammo-body for the walls to static and the avatar to dynamic.
While the collision logic would need a collider, there are many different ones you can research and test out what works for you the best.
提问者确实需要一个导航网格。但是,对于那些寻找标题问题(如何使某物沿着预定路径移动)答案的人,请参阅此存储库以及包含的
follow-path
组件:https://github.com/kylebakerio/aframe-curve-component
The question asker really does need a nav mesh. However, for those looking for an answer to the headline question (how to make something move along a predetermined path), see this repo, and the included
follow-path
component:https://github.com/kylebakerio/aframe-curve-component