当前位置: 首页 > article >正文

Cesiumlab发布3dtiles白膜流程与前端可视化加载

Cesiumlab发布3dtiles白膜流程与前端可视化加载

1.前置准备

1.1 安装CesiumLab并注册(CesiumLab安装、CesiumLab账号注册以及不同授权类型的说明 CesiumLab系列教程 - 知乎 (zhihu.com));

1.2 最好安装有Qgis可以进行简单数据处理(如果有完整数据可以不用)(qgis3.32安装包-CSDN博客)

1.3 了解cesium.js

1.4 准备好数据(shpfile、obj等)(数据:【免费】北京各城区shpfile数据资源-CSDN文库)

2.处理流程

2.1.打开cesiumLab,选择数据处理–> 通用模型切片:

在这里插入图片描述
在这里插入图片描述

2.2.在输入文件中选择 +SHP,导入shpfile文件,并设置shpfile文件高度为根据floor层高来拉伸

在这里插入图片描述

2.3.选择资源库位置,随便在一个文件夹下都行,命一下名

在这里插入图片描述

2.4.全选字段,让字段信息载入到最终生成的3dtile的属性里,存储类型设置为散列,选择输出位置,提交处理即可

在这里插入图片描述

2.5.cesiumLab中浏览

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

3.前端页面中加载:

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title></title>
    <style>
        *{
            margin: 0;
            padding: 0;
            overflow: hidden;
        }
        #cesiumContainer{
            width: 100vw;
            height: 100vh;
        }
    </style>
    <script src="../node_modules/cesium/Build/Cesium/Cesium.js"></script>
    <!-- <link href="../node_modules/cesium/Build/Cesium/Widgets/widgets.css"> -->
    <style>
        @import url(../node_modules/cesium/Build/Cesium/Widgets/widgets.css);
      </style>


</head>
<body>
    <div id="cesiumContainer" style="width: 100vw; height: 100vh;">
    </div>

    <script>
        Cesium.Ion.defaultAccessToken = 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqdGkiOiI0NTEzNGViNC0zZDBkLTRlODktOGViOC0yODg5ODQ4YmQ5YzYiLCJpZCI6MTAzMTUxLCJpYXQiOjE2NTkzMTU5MjJ9.L7FacAYyOisZNsuk7ojO57iiuNB5Xgxm4dqV45DB994';
        let viewer = new Cesium.Viewer("cesiumContainer");

        //
        let weblayer = new Cesium.Cesium3DTileset({
            url:"../../data/yanqing/tileset.json",
            skipLevelOfDetail: true,
            skipLevels: 4,
            baseScreenSpaceError: 1024,
            maximumScreenSpaceError: 256, // 数值加大,能让最终成像变模糊
            skipScreenSpaceErrorFactor: 16,
            immediatelyLoadDesiredLevelOfDetail: true,
            loadSiblings: true, // 如果为true则不会在已加载完概况房屋后,自动从中心开始超清化房屋
            cullWithChildrenBounds: true,
            cullRequestsWhileMoving: true,
            cullRequestsWhileMovingMultiplier: 10, // 值越小能够更快的剔除
            preloadWhenHidden: true,
            preloadFlightDestinations: false,
            preferLeaves: true,
            maximumMemoryUsage: 128, // 内存分配变小有利于倾斜摄影数据回收,提升性能体验
            progressiveResolutionHeightFraction: 0, // 数值偏于0能够让初始加载变得模糊
            dynamicScreenSpaceErrorDensity: 0.5, // 数值加大,能让周边加载变快
            dynamicScreenSpaceErrorFactor: 1,
            dynamicScreenSpaceError: true, // 根据测试,有了这个后,会在真正的全屏加载完之后才清晰化房屋
        });
        viewer.scene.primitives.add(weblayer);

        viewer.flyTo(weblayer);

    </script>
</body>
</html>

视频演示地址:https://blog.csdn.net/qq_44849312/article/details/143024086


http://www.kler.cn/a/353983.html

相关文章:

  • Android12 App窗口创建流程
  • 常见的框架漏洞复现
  • Python入门系列之九-数据分析与可视化进阶
  • 使用 C++ 和函数式编程构建高效的 AI 模型
  • 气膜球幕:引领元宇宙时代的科技与艺术光影盛宴—轻空间
  • kernel32.dll动态链接库报错要怎解决?详细解析kernel32.dll文件缺失解决方案
  • 基于SpringBoot的课程辅助教学系统
  • 信息收集笔记
  • 基于卷积神经网络的蔬菜识别系统,resnet50,mobilenet模型【pytorch框架+python源码】
  • 安装mysql 5.5.62
  • 【人工智能】实验室GPU资源申请使用
  • 视频云存储/音视频流媒体视频平台EasyCVR视频汇聚平台在欧拉系统中启动失败是什么原因?
  • 3-4 AUTOSAR RTE对CS Port的实现
  • 人脸识别-特征算法
  • HarmonyOS preferences存储
  • SwiftUI 6.0(iOS 18)自定义容器值(Container Values)让容器布局渐入佳境(上)
  • 开源模型应用落地-Qwen2.5-7B-Instruct与vllm实现推理加速的正确姿势-Docker-Tools助力(四)
  • 《Spring Cloud 微服务:构建高效、灵活的分布式系统》
  • 搭建知识付费小程序要哪些资质?
  • 无人机+视频推流直播EasyCVR视频汇聚/EasyDSS平台在森林防护巡检中的解决方案
  • PDF全能免费转换 3.15 | 多功能PDF处理工具
  • CSS @规则(At-rules)系列详解___@counter-style 规则使用方法
  • 如果使用 Iptables 配置端口转发 ?
  • npm install node-sass安装失败
  • CI/CD(持续集成与持续交付)流水线
  • Prometheus运维监控平台之监控指标注册到consul脚本开发、自定义监控项采集配置调试(三)