iClient3D 图元操作

1. S3MTilesLayer,S3M(Spatial 3D Model)图层类

S3MTilesLayer,S3M(Spatial 3D Model)图层类,通过该图层实现加载三维切片缓存,包括倾斜摄影模型、BIM模型、点云数据、精细模型、矢量数据、符号等。

那S3MTilesLayer中针对图元的操作主要有'颜色','偏移','可见性''等

2. 图元操作之颜色

1.临时选中高亮:即鼠标选中其他对象或者不选中时,不再高亮;

这种情况可直接设置图层的selectedColor

javascript 复制代码
layer.selectedColor = Cesium.Color.RED

若是经过查询获取的id,可以调用setSelection(id),设置该对象选中并高亮

2.设置图元颜色

javascript 复制代码
let selectedId = [15051, 15052, 17076, 17057, 17037, 17056, 17036, 15072, 14322, 17174, 16872, 16873]
    let Colors= ['#152664','#0d2680','#002eb3','#0041a2','#005ebc','#1b75cf','#0080ff', '#2baaf9','#55d7f8','#8cedff','#b1f1ff','#F0FFFF']
    // 设置图元颜色
    function setColor(){
       for (let i = 0; i < selectedId.length; i++) {
            layer.setObjsColor([selectedId[i]], Cesium.Color.fromCssColorString(Colors[i]))
        }
    }
    // 删除相应id的图元颜色
    function removeColor(){
      layer.removeObjsColor(selectedId.slice(0,5))
    }
    // 删除所有图元的颜色
    function removeAllColor(){
        layer.removeAllObjsColor()
    }

3. 图元操作之可见性

可见性的操作主要分为两种,

一.不互斥,即设置图元自身的可见性,不影响其他图元:

使用setOnlyObjsVisible(ids, isVisible)

javascript 复制代码
// 设置图元可见
    function setOnlyObjsVisible(){
      layer.setOnlyObjsVisible(selectedId,true)
    }
    // 设置图元不可见
    function setOnlyObjsDisVisible(){
        layer.setOnlyObjsVisible(selectedId,false)
    }

二.互斥,设置图元自身的可见性,会影响其他图元的可见性:

使用setObjsVisible(ids, isVisible)

javascript 复制代码
// 互斥:设置图元可见
    function setObjsVisible(){
      layer.setObjsVisible(selectedId,true)
    }
    // 互斥:设置图元不可见
    function setObjsDisVisible(){
        layer.setObjsVisible(selectedId,false)
    }

4. 图元操作之偏移

偏移和其他三种不太一样,设置的偏移参数是设置图层的selectedTranslate属性,而不是在set方法里面设定偏移参数

javascript 复制代码
layer.selectedTranslate = new Cesium.Cartesian3(5, 0, 0)
layer.setObjsOffset([selectedId2])
相关推荐
Southern Wind3 分钟前
Vue 3 多实例 + 缓存复用:理念及实践
前端·javascript·vue.js·缓存·html
前端拿破轮37 分钟前
从0到1搭一个monorepo项目(一)
前端·javascript·git
xingxing_F1 小时前
Rhino 8 for Mac 犀牛3D建模软件
macos·3d
Mintopia1 小时前
🎨 AIGC 内容过滤技术:当创作的洪流遇上理性的堤坝
前端·javascript·aigc
Shi_haoliu2 小时前
Vue2 + Office Add-in关于用vue项目于加载项控制excel单元格内容(Demo版)
前端·javascript·vue.js·node.js·html·excel·office
aesthetician5 小时前
Node.js v25 重磅发布!革新与飞跃:深入探索 JavaScript 运行时的未来
javascript·node.js·vim
demi_meng9 小时前
reactNative 遇到的问题记录
javascript·react native·react.js
千码君201610 小时前
React Native:从react的解构看编程众多语言中的解构
java·javascript·python·react native·react.js·解包·解构
EndingCoder12 小时前
WebSocket实时通信:Socket.io
服务器·javascript·网络·websocket·网络协议·node.js
我胡为喜呀12 小时前
Vue3 中的 watch 和 watchEffect:如何优雅地监听数据变化
前端·javascript·vue.js