Cesium高性能渲染海量矢量建筑

0、数据输入为类似Geojson的压缩文件和纹理图片,基于DrawCommand命令绘制;

1、自定义建筑几何,包括顶点、法线、纹理等;

2、自定义纹理贴图,包括按建筑高度贴图、mipmap多级纹理;

3、自定义批处理表,支持显示控制和鼠标交互。

效果

部分代码

<!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>北京建筑</title><script src="./js/config.js"></script><script src="./scripts/vue.min.js"></script><link rel="stylesheet" href="./css/common.css" /><script type="text/javascript" src="../anov-gis-sdk/index.js"></script><link rel="stylesheet" href="../anov-gis-sdk/index.css" /><script type="text/javascript" src="./scripts/element.index.js"></script><link rel="stylesheet" href="./scripts/element.index.css"><!-- <script src="https://cdn.jsdelivr.net/npm/pbf"></script> -->
</head><body><div id="global"></div><script type="module">import CustomPrimitive from './html/performance/CustomPrimitive.js';import CustomTexture from './html/performance/CustomTexture.js';import CustomWallGeometry from './html/performance/CustomWallGeometry.js';import { showLoading, hideLoading, setText } from './html/performance/loadingUtil.js';new Vue({el: "#global",template: `<div id="cesiumContainer"></div>`,mounted() {this.init3D();this.addTestPrimitive();setTimeout(() => {showLoading();this.creatWall();}, 1000);setTimeout(() => {console.log('viewer.scene.frameState.commandList', viewer.scene.frameState.commandList);}, 5000);},methods: {init3D() {window.viewer = new ANOVGIS.Viewer("cesiumContainer", {contextOptions: {id: "cesiumCanvas",webgl: {preserveDrawingBuffer: false,},showRenderLoopErrors: true,},geocoderType: ANOVGIS.GeocoderType.TIANDITU,vrButton: false,baseLayerPicker: true,fullscreenButton: true,homeButton: true,sceneModePicker: true,navigationHelpButton: true,copyRight: false,showMapInfo: true,drillPick: false,});top.viewer = window.viewer;viewer.setOptions({enableFxaa: true,});viewer.nativeObjCesium.shadowMap.maximumDistance = 1300;let time = 0;setInterval(() => {// 改变时间设置光照效果let date = new Date().getTime() + timelet utc = Cesium.JulianDate.fromDate(new Date(date))//北京时间viewer.nativeObjCesium.clockViewModel.currentTime = Cesium.JulianDate.addHours(utc, 8, new Cesium.JulianDate())time = time + 5000 * 60}, 100)},locate() {ANOVGIS.LocateUtil.flyToPosition(viewer, '116.4244631,39.8453427', 0, -35, 5000, 2, null);},creatWall() {this.addBuildingWallsToViwer(0, datasArr);},async addBuildingWallsToViwer(indexB, arr) {// 模拟异步操作},getFile(path, callback) {return fetch(path, {responseType: 'arraybuffer'}).then(res => {return res.arrayBuffer();}).then(data => {let geojson = geobuf.decode(new Pbf(data))callback(geojson);})},addWallPrimitive(buildingMaterial) {const buildsArr = buildingMaterial.buildingdatas;const customWallGeometry = new CustomWallGeometry({buildsArr,textureWidth: buildingMaterial.textureWidth});const geometryCombined = customWallGeometry.createGeometry(buildsArr);const attributeLocations = {position3DHigh: 0,position3DLow: 1,normal: 2,st: 3};let texture;const customTexture = new CustomTexture();customTexture.getMipmapTexture(viewer.scene.context, '../modelData/building/' + buildingMaterial.material[0], (t) => {texture = t;});const customPrimitive = new CustomPrimitive({geometry: geometryCombined,attributeLocations: attributeLocations,receiveShadows: true,castShadows: true,})return viewer.scene.primitives.add(customPrimitive);},addBuildTops(buildingMaterial) {const buildsArr = buildingMaterial.buildingdatas;const topsInstancesArr = [];for (let index = 0; index < buildsArr.length; index++) {const element = buildsArr[index];const positionsCartesian3 = element.positions;const buildingHeight = element.height;const topInstance = new Cesium.GeometryInstance({geometry: Cesium.PolygonGeometry.createGeometry(new Cesium.PolygonGeometry({polygonHierarchy: new Cesium.PolygonHierarchy(positionsCartesian3),height: buildingHeight}))});topsInstancesArr.push(topInstance);}const geometryCombined = Cesium.GeometryPipeline.combineInstances(topsInstancesArr)[0];const attributeLocations = {position3DHigh: 0,position3DLow: 1,normal: 2,st: 3};let texture;const customTexture = new CustomTexture();customTexture.getMipmapTexture(viewer.scene.context, '../modelData/building/' + buildingMaterial.topMaterial[0], (t) => {texture = t;})const topsPrimitive = new CustomPrimitive({geometry: geometryCombined,attributeLocations: attributeLocations,receiveShadows: true,castShadows: false,uniformMap: {myImage: () => {if (Cesium.defined(texture)) {return texture;} else {return viewer.scene.context.defaultTexture;}}},})return viewer.scene.primitives.add(topsPrimitive);},}})</script>
</body></html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/876073.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

DVWA中命令执行漏洞细说

在攻击中&#xff0c;命令注入是比较常见的方式&#xff0c;今天我们细说在软件开发中如何避免命令执行漏洞 我们通过DVWA中不同的安全等级来细说命令执行漏洞 1、先调整DVWA的安全等级为Lower,调整等级在DVWA Security页面调整 2、在Command Injection页面输入127.0.0.1&…

AI在Facebook的应用:预见智能化社交的新前景

在数字化时代&#xff0c;社交媒体平台已成为我们生活的重要组成部分&#xff0c;而人工智能&#xff08;AI&#xff09;的快速发展正推动着这些平台向更智能、更个性化的方向发展。Facebook&#xff0c;作为全球最大的社交网络平台之一&#xff0c;正不断探索和应用AI技术&…

mysql面试(七)

前言 本章节列出了mysql在增删改查的时候&#xff0c;分别会涉及到哪些锁类型&#xff0c;又是如何交互的。 这个章节也是mysql面试基础系列的最后一章&#xff0c;后面准备更新redis数据类型和分布式锁相关问题。如果各位看官有什么问题的话&#xff0c;可以留言。 锁 之前…

【MySQL进阶之路 | 高级篇】MVCC三剑客:隐藏字段,Undo Log,ReadView

1. 再谈隔离级别 我们知道事务有四个隔离级别&#xff0c;可能存在三种并发问题&#xff1a; 在MySQL中&#xff0c;默认的隔离级别是可重复读&#xff0c;可以解决脏读和不可重复读的问题&#xff0c;如果仅从定义的角度来看&#xff0c;它并不能解决幻读问题。如果我们想要解…

2024年jupyter notebook如何复制单元格cell输出的图片

背景 之前使用jupyter notebook复制图片一直是正常&#xff0c;右键就行&#xff0c;可以找到复制图片或者另存为的选项。 但是最近重新安装了anaconda&#xff0c;发现jupyter notebook升级了&#xff0c;和原来的界面不一样了。 如果有一个图片&#xff0c;我们右键&#x…

【Linux】—管理、设置防火墙规则(firewalld详解)

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:Linux运维老纪的首页…

[OJ]平均串问题,存在超时问题未解决

众所周知&#xff0c;两个数a和b的平均数计算公式为(ab)/2。 实际上平均数也可以描述为&#xff1a;从较小的数依次遍历到较大的数&#xff0c;将遍历的数放入一个列表中&#xff0c;该列表的中心元素。例如&#xff1a;求 3和7的平均数&#xff0c;列表为{3,4,5,6,7}&#xff…

2024-06学习笔记

1.事务与数据库链接的占用 如果用Transactional注解&#xff0c;那在第一次与数据库交互的时候&#xff0c;就会打开数据库链接&#xff0c;再整个方法执行完&#xff0c;才会关闭数据库链接。 即使后边用的事务传播是required_new,那之前的事务也是被挂起&#xff0c;不会被…

静态路由学习笔记

1. 静态路由应用场景 &#xff08;1&#xff09;静态路由由网络管理员手动配置&#xff0c;配置方便&#xff0c;对系统要求低&#xff0c;适用于拓扑结构简单并且稳定的小型网络。 &#xff08;2&#xff09;缺点是不能自动适应网络拓扑的变化&#xff0c;需要人工干预过多。…

day05 Router、vuex、axios

配置 router和vuex需要在创建vue项目的时候&#xff0c;开始的时候选择Manually select features&#xff0c;于是就可以在下一个创建配置讯问中选择router和vuex。 axios则需要执行命令行&#xff1a; npm install axios -S 之后再在需要发送请求的view导入即可。 router…

研发(RD)注意事项 / 复杂项目规划、控制方法 PERT 和 CPM

注&#xff1a;机翻&#xff0c;未校对&#xff0c;去掉了原文中广告。 What Is Research and Development (R&D)? 什么是研发&#xff08;R&D&#xff09;&#xff1f; Investopedia / Ellen Lindner Research and Development An ongoing effort to develop or impr…

springboot中使用knife4j访问接口文档的一系列问题

springboot中使用knife4j访问接口文档的一系列问题 1.个人介绍 &#x1f389;&#x1f389;&#x1f389;欢迎来到我的博客,我是一名自学了2年半前端的大一学生,熟悉的技术是JavaScript与Vue.目前正在往全栈方向前进, 如果我的博客给您带来了帮助欢迎您关注我,我将会持续不断的…

Hive3:Centos7环境部署Hive服务

一、安装说明 1、Hadoop集群情况 3台机器&#xff1a;4G2C、2G2C、2G2C 安装教程&#xff1a;Centos7环境安装Hadoop集群 2、安装MySQL&#xff0c;用于存储Hive的元数据 在102机器上安装MySQL 安装MySQL使用服务器的root账号 3、最后安装Hive 安装hive过程使用服务器的atgu…

【C++】选择结构案例-三目运算符

三目运算符语法格式&#xff1a; 布尔表达式?表达式1:表达式2 运算过程&#xff1a;如果布尔表达式的值为 true &#xff0c;则返回 表达式1 的值&#xff0c;否则返回 表达式2 的值 &#xff08;三目运算符指的是&#xff1f;和&#xff1a;&#xff09; 在这个三目运算符…

postman请求响应加解密

部分接口&#xff0c;需要请求加密后&#xff0c;在发动到后端。同时后端返回的响应内容&#xff0c;也是经过了加密。此时&#xff0c;我们先和开发获取到对应的【密钥】&#xff0c;然后在postman的预执行、后执行加入js脚本对明文请求进行加密&#xff0c;然后在发送请求&am…

【游戏制作】使用Python创建一个完整的2048游戏项目

目录 项目运行展示 项目概述 项目目标 项目结构 安装依赖 代码实现 1. 导入库 2. 创建 Game2048 类 3. 设置UI界面 4. 加载二维码图片 5. 创建菜单 6. 游戏逻辑和功能 7. 运行应用 总结 创建一个完整的2048游戏项目 项目运行展示 项目概述 在这个项目中&#xff…

Mysql中如何实现两列的值互换?给你提供些思路。

文章目录 Mysql中如何实现两列的值互换1、第一感觉此sql应该能处理问题了2、需要一个地方存要替换的值&#xff0c;不然两列搞不定。2.1 加第三列&#xff1f;&#xff08;能解决&#xff0c;但是看起来呆呆&#xff09;2.2 上临时表&#xff08;搞点弯路走走&#xff09; 示例…

如何在 SpringBoot 中优雅的做参数校验?

一、故事背景 关于参数合法性验证的重要性就不多说了&#xff0c;即使前端对参数做了基本验证&#xff0c;后端依然也需要进行验证&#xff0c;以防不合规的数据直接进入服务器&#xff0c;如果不对其进行拦截&#xff0c;严重的甚至会造成系统直接崩溃&#xff01; 本文结合…

昇思25天学习打卡营第24天|RNN实现情感分类

RNN实现情感分类学习总结 概述 情感分类是自然语言处理领域的重要任务&#xff0c;主要用于识别文本中表达的情绪。本文使用MindSpore框架实现基于RNN的情感分类模型&#xff0c;示例包括&#xff1a; 输入: “This film is terrible” -> 标签: Negative输入: “This fi…

UE5.4内容示例(1)- 学习笔记

https://www.unrealengine.com/marketplace/zh-CN/product/content-examples 《内容示例》是学习UE5的基础示例&#xff0c;可以用此示例熟悉一遍UE5的功能 模型与材质部分 StaticMeshes FBX_Import_Options Material_Advanced Material_Decals Material_Instances Material_N…