Cesium左键点击模型效果怎么实现

Cesium左键点击模型效果怎么实现

这篇文章给大家介绍Cesium左键点击模型效果怎么实现,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

Cesium的样例中,有一个3D Tiles Feature Picking,鼠标划过模型,会在模型上显示一个选中框,在模型旁边浮现一个名称标签,点击3dtiles中的模型,会高亮显示框,并且弹出模型的详细信息。


直接拿过来使用其中的代码,发现这个点击效果,是要根据模型(3dtile)的实际情况进行代码修改,鼠标点击到的模型是b3dm格式的,Cesium有详细的文件格式说明,不过文件的有些部分需要可以进行省略,所以,导致不是每个3dtile的图层都是一样。

b3dm文件格式参见网址:https://github.com/AnalyticalGraphicsInc/3d-tiles/blob/master/TileFormats/Batched3DModel/README.md

在实际的代码中,按照以下情况进行修改,完全代码参照文章开头的网址,以下只对关键代码进行解释:

if (Cesium.defined(highlighted.feature)) {

//此代码处,要根据模型,判断feature中是否存在color的属性,否则设置不成功

highlighted.feature.color = highlighted.originalColor;

highlighted.feature = undefined;

}

//要根据模型,判断feature中是否存在color的属性,否则设置不成功

pickedFeature.color = Cesium.Color.LIME;

// 这处要判断是否有name的属性,这个和b3dm的batch Table和feature Table有关联,需看b3dm模型中是否有以上这些

var featureName = pickedFeature.getProperty('name');

selectedEntity.name = featureName;

selectedEntity.description = 'Loading <div class="cesium-infoBox-loading"></div>';

viewer.selectedEntity = selectedEntity;

selectedEntity.description = .............;

在MOUSE_MOVE和LEFT_CLICK都有对应的代码,需要同时都进行修改。

关于Cesium左键点击模型效果怎么实现就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

发布于 2021-12-28 22:19:54
收藏
分享
海报
0 条评论
37
上一篇:TE中管线生成工具怎么用 下一篇:Laravel 5.7开发博客应用之如何创建项目和测试配置
目录

    0 条评论

    本站已关闭游客评论,请登录或者注册后再评论吧~

    忘记密码?

    图形验证码