收藏
回答

xr-frame内部节点增加shape不能使用autoFit或者不能使用mesh-shape?

    handleGLTFLoaded({ detail }) {
      const el = detail.value.target;

      const gltf = el.getComponent("gltf");
      // 支架的刚体形状
      const ballonGLTF = gltf.getInternalNodeByName("支架");
      ballonGLTF.addComponent(xrFrameSystem.CubeShape,{size: [0.2,3.5,0.2],center:[0,0.3,0]}); //
      // ballonGLTF.addComponent(xrFrameSystem.ShapeGizmos)
      ballonGLTF.addComponent(xrFrameSystem.ShapeInteract, { collide: true, bounciness: 0 });


      // cube的刚体形状
      const cube = gltf.getInternalNodeByName("ground");
      cube.addComponent(xrFrameSystem.CubeShape,{autoFit:true});
      // cube.addComponent(xrFrameSystem.ShapeGizmos)
      cube.addComponent(xrFrameSystem.ShapeInteract,{ collide: true, bounciness: 0 });
    

      // 球框左挡板
      const left = gltf.getInternalNodeByName("left");
      left.addComponent(xrFrameSystem.MeshShape,{size: [2,0.02,2]});
      // left.addComponent(xrFrameSystem.ShapeGizmos)
      left.addComponent(xrFrameSystem.ShapeInteract, { collide: true, bounciness: 0 });
    }
 上面的代码展示了就是在GLTF加载成功之后,我需要对内部节点进行碰撞或者重叠检测,但是发现只能按照 “支架”那段代码为例子进行添加shape,然后才能进行碰撞检测。
 增加CubeShape组建,设置autoFit:true,我log输出检查时设置成功的,但是不进行碰撞检测。
 
增加meshShape组建,也是设置成功了但是无法进行碰撞检测。
 
 请教下,autoFit参数或者MeshShape,只能作用于这个gltf整体,而不能作用于内部组件。是因为缺少包围盒盒包围球吗?那么我blender导出模型的时候应该怎么做?


最后一次编辑于  10-23
回答关注问题邀请回答
收藏

1 个回答

  • div
    div
    11-02

    可以进微信群里问下,应该有人遇到过,不过人太多了,只能+wx:wdmwjm ,邀请进

    11-02
    有用
    回复
登录 后发表内容