三维GIS开发cesium智慧地铁教程(4)城市白模加载与样式控制

一、添加3D瓦片

复制代码
<!-- 核心依赖引入 -->
<script src="../cesium1.99/Build/Cesium/Cesium.js"></script>
<link rel="stylesheet" href="../cesium1.99/Build/Cesium/Widgets/widgets.css">

<!-- 模型数据路径 -->
url: '../wuhan3/tileset.json'

二、3D Tiles技术栈

1. 3D Tiles规范

复制代码
const tileset = viewer.scene.primitives.add(
    new Cesium.Cesium3DTileset({...})
)
  • 数据分块:LOD层级划分的瓦片结构
  • 格式特点:支持glTF、b3dm等三维格式
  • 空间索引:四叉树空间索引机制

模型加载流程:

三、核心代码

1. 模型加载模块

复制代码
const tileset = viewer.scene.primitives.add(
    new Cesium.Cesium3DTileset({
        url: '../wuhan3/tileset.json' // 模型入口文件
    })
)

技术要点:

  • primitivesentities的区别:Primitives用于高性能渲染,Entities用于交互式实体
  • 模型坐标系:自动匹配WGS84坐标系

2. 异步加载控制

复制代码
tileset.readyPromise.then(function () {
    // 样式设置代码
})

3. 条件着色系统

复制代码
tileset.style = new Cesium.Cesium3DTileStyle({
    color: {
        conditions: [
            ["Number(${Elevation})<20", "color('rgb(0, 0, 0)',0.0)"],
            ["Number(${Elevation})>20", "color('rgb(74, 79, 19)',0.4)"],
        ]
    }
})
  • ${Elevation}:模型自带的元数据属性
  • Number():类型转换函数
  • color():颜色构造函数,参数格式为(CSS颜色, 透明度)

4. 场景定位控制

复制代码
viewer.flyTo(tileset)

镜头运动参数:

  • 默认飞行时间:3秒
  • 自动计算最佳视距
  • 平滑的相机路径规划

四、模型调试技巧

1. 属性查看方法

复制代码
// 在控制台查看模型属性
console.log(tileset.properties);

2. 样式调试工具

复制代码
// 实时更新样式
tileset.style = new Cesium.Cesium3DTileStyle({
    show: '${Elevation} > 50' // 显示过滤条件
});

五、智慧地铁项目衔接

数据对接准备

|--------|----------------|----------|
| 数据类型 | 对接方式 | 应用场景 |
| 地铁线路规划 | GeoJSON路径导入 | 线路可视化 |
| 站点信息 | CZML时序数据 | 运营状态动态展示 |
| 客流数据 | 热力图着色 | 拥挤度可视化 |
| 设备信息 | 自定义Billboard图标 | 设备定位 |

完整代码:

复制代码
<!DOCTYPE html>
<html lang="en">


<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../cesium1.99/Build/Cesium/Cesium.js"></script>
    <link rel="stylesheet" href="../cesium1.99/Build/Cesium/Widgets/widgets.css">
    <style>
        * {
            margin: 0;
            padding: 0;
        }


        #cesiumContainer {
            width: 100vw;
            height: 100vh;
            overflow: hidden;
        }
    </style>

</head>

<body>
    <div id="cesiumContainer">
    </div>
</body>

<script>
    Cesium.Ion.defaultAccessToken = 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqdGkiOiIwYzhiZTM4ZC0yN2NiLTQ5MjQtOWRjMS1hOGY2Y2ZhMGQ3MzAiLCJpZCI6MTE1MTg3LCJpYXQiOjE2OTIzNDczMzh9.Ealj0HH4x_WU4fG5dI2XvnBNeNNhq5rXjBFsmDgt-mg'
    const viewer = new Cesium.Viewer('cesiumContainer')
    const tileset = viewer.scene.primitives.add(
        new Cesium.Cesium3DTileset({
            url: '../wuhan3/tileset.json'
        })
    )
    tileset.readyPromise.then(function () {
        // 处理模型着色
        tileset.style = new Cesium.Cesium3DTileStyle({
            color: {
                conditions: [
                    ["Number(${Elevation})<20", "color('rgb(0, 0, 0)',0.0)"],
                    ["Number(${Elevation})>20", "color('rgb(74, 79, 19)',0.4)"],
                ],
                show: false,
            },
        });
    });
    viewer.flyTo(tileset)
</script>


</html>
相关推荐
rufeike2 小时前
Redis学习笔记
redis·笔记·学习
重庆小透明4 小时前
【从零开始学习JVM | 第六篇】运行时数据区
java·jvm·后端·学习
晨曦backend6 小时前
Vim 替换命令完整学习笔记
笔记·学习·vim
liuyang___7 小时前
日期的数据格式转换
前端·后端·学习·node.js·node
蒙奇D索大7 小时前
【11408学习记录】[特殊字符] 速解命题核心!考研数学线性代数:4类行列式满分技巧(含秒杀公式)
笔记·学习·线性代数·考研·改行学it
哆啦A梦的口袋呀8 小时前
基于Python学习《Head First设计模式》第十章 状态模式
学习·设计模式
moxiaoran57538 小时前
uni-app学习笔记三十六--分段式选项卡组件的使用
笔记·学习·uni-app
栗子不爱栗子9 小时前
从理解AI到驾驭文字:一位技术爱好者的写作工具探索手记
python·学习·ai
sjg2001041411 小时前
golang学习随便记x[2,3]-字符串处理与正则表达式
开发语言·学习·golang
fictionist11 小时前
动态 Web 开发技术入门篇
java·服务器·开发语言·笔记·学习·mysql·spring