3D Tiles高级样式设置与条件渲染(3)

二、基于地理距离的条件渲染

1.根据与特定点的距离设置样式

在某些应用中,我们可能需要根据建筑物与某个特定点(如地标建筑)的距离来设置样式。以下代码示例展示了如何根据建筑物与广州塔的距离来设置颜色和可见性:

javascript 复制代码
tiles3d.style = new Cesium.Cesium3DTileStyle({
    // 定义一些变量,这些变量可以在样式中使用
    defines: {
        // 定义一个名为distance的变量,计算每个瓦片与指定经纬度点(113.3191, 23.109)的距离
        distance: "distance(vec2(${feature['cesium#longitude']},${feature['cesium#latitude']}), vec2(113.3191, 23.109))"
    },
    // 设置瓦片的颜色
    color: {
        // 根据条件动态设置颜色
        conditions: [
            // 如果距离小于0.01度
            ["${distance} < 0.01", "color('rgba(0,0,50, 0.7)')"], // 设置为半透明的深蓝色
            // 如果距离小于0.02度
            ["${distance} < 0.02", "color('rgba(0,0,50, 0.5)')"], // 设置为半透明的蓝色
            // 如果距离小于0.04度
            ["${distance} < 0.04", "color('rgba(0,0,50, 0.2)')"], // 设置为半透明的浅蓝色
            // 其他情况
            ["true", "color('white')"] // 设置为白色
        ]
    },
    // 设置瓦片的显示条件
    show: "${distance} < 0.04 && ${feature['building']} === 'apartments'"
    // 只有当距离小于0.04度且建筑类型为'apartments'时,瓦片才显示
});
相关推荐
Younglina7 分钟前
一个纯前端的网站集合管理工具
前端·vue.js·chrome
木头程序员8 分钟前
前端(包含HTML/JavaScript/DOM/BOM/jQuery)基础-暴力复习篇
开发语言·前端·javascript·ecmascript·es6·jquery·html5
卖火箭的小男孩10 分钟前
# Flutter Provider 状态管理完全指南
前端
小雨青年10 分钟前
鸿蒙 HarmonyOS 6|ArkUI(01):从框架认知到项目骨架
前端
Null15513 分钟前
浏览器唤起本地桌面应用(基础版)
前端·浏览器
ZFB000125 分钟前
【麒麟桌面系统】V10-SP1 2503 系统知识——添加用户
linux·运维·kylin
pas13628 分钟前
31-mini-vue 更新element的children
前端·javascript·vue.js
wordbaby32 分钟前
TanStack Router 实战:如何构建经典的“左侧菜单 + 右侧内容”后台布局
前端·react.js
ZFB000142 分钟前
【麒麟桌面系统】V10-SP1 2503 系统知识——进入救援模式
linux·运维·kylin
RisunJan44 分钟前
Linux命令-iptables-restore命令(从文件批量恢复 iptables 防火墙规则)
linux·运维·网络