Cesium从入门到放弃:模型压平

2023-11-22 18:21

本文主要是介绍Cesium从入门到放弃:模型压平,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

模型压平这个功能在Cesium界很神秘,其他功能百度一下都能找到几行代码,找不到代码也能找到思路,只有这个,找到的全是视频,下面是我研究后的一点思路,供大家参考。

思考

  1. 模型压平究竟做了什么?
    简单来说就是给定一个平面,如果模型的高度大于该平面,该将其高度设为该平面的高度,否则保持不变。
if (position.z > planeHeight) {position.z = planeHeight;
}

核心就是上面这行代码,哪么下一个问题来了, position是什么坐标。

  1. 应该在什么坐标系中比较模型和平面的高度?
    我们在顶点着色器中可以拿到的坐标特别多,他们是模型在不同坐标系中的顶点坐标,理论上,我们可以在任意坐标系下计算,只需要让平面和模型在同一坐标系下即可。但是最符合人们思维习惯的应该是在以模型中心为原点的,Z轴垂直该平面向上的坐标系中计算

代码

cesium1.84以上,支持用户对模型添加自定义着色器,如此,我们甚至不需要修改源码,就可以实现该功能

const inverseModelLocal = new Matrix4();
const modelLocal = new Matrix4();
const model = new Cesium3DTileset({// url: '../Apps/SampleData/Cesium3DTiles/Tilesets/Tileset/tileset.json',url: './dayanta/tileset.json',customShader: new CustomShader({uniforms: {u_inverseLocalModel: {type: UniformType.MAT4,value: inverseModelLocal},u_localModel: {type: UniformType.MAT4,value: modelLocal},u_planeHeight: {type: UniformType.FLOAT,value: -20}},vertexShaderText: `void vertexMain(VertexInput vsInput, inout czm_modelVertexOutput vsOutput) {vec4 positionWC = u_inverseLocalModel * czm_model * vec4(vsInput.attributes.positionMC, 1.0);  if (positionWC.z > u_planeHeight) {positionWC.z = u_planeHeight;}vsOutput.positionMC = (czm_inverseModel * u_localModel * positionWC).xyz;   }`,})
});
model.readyPromise.then((v) => {const center = v.boundingSphere.center;model.localView = Transforms.eastNorthUpToFixedFrame(center, viewer.scene.globe.ellipsoid, modelLocal);      model.localViewInverse = Matrix4.inverse(modelLocal, inverseModelLocal);})viewer.flyTo(model)

附上一张效果图
在这里插入图片描述

TODO

  1. 多个矩形区域的压平
  2. 压平后闪面问题如何解决

这篇关于Cesium从入门到放弃:模型压平的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/412041

相关文章

详解如何使用Python从零开始构建文本统计模型

《详解如何使用Python从零开始构建文本统计模型》在自然语言处理领域,词汇表构建是文本预处理的关键环节,本文通过Python代码实践,演示如何从原始文本中提取多尺度特征,并通过动态调整机制构建更精确... 目录一、项目背景与核心思想二、核心代码解析1. 数据加载与预处理2. 多尺度字符统计3. 统计结果可

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.

SpringBoot整合Sa-Token实现RBAC权限模型的过程解析

《SpringBoot整合Sa-Token实现RBAC权限模型的过程解析》:本文主要介绍SpringBoot整合Sa-Token实现RBAC权限模型的过程解析,本文给大家介绍的非常详细,对大家的学... 目录前言一、基础概念1.1 RBAC模型核心概念1.2 Sa-Token核心功能1.3 环境准备二、表结

POI从入门到实战轻松完成EasyExcel使用及Excel导入导出功能

《POI从入门到实战轻松完成EasyExcel使用及Excel导入导出功能》ApachePOI是一个流行的Java库,用于处理MicrosoftOffice格式文件,提供丰富API来创建、读取和修改O... 目录前言:Apache POIEasyPoiEasyExcel一、EasyExcel1.1、核心特性

Python中模块graphviz使用入门

《Python中模块graphviz使用入门》graphviz是一个用于创建和操作图形的Python库,本文主要介绍了Python中模块graphviz使用入门,具有一定的参考价值,感兴趣的可以了解一... 目录1.安装2. 基本用法2.1 输出图像格式2.2 图像style设置2.3 属性2.4 子图和聚

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

Python FastAPI入门安装使用

《PythonFastAPI入门安装使用》FastAPI是一个现代、快速的PythonWeb框架,用于构建API,它基于Python3.6+的类型提示特性,使得代码更加简洁且易于绶护,这篇文章主要介... 目录第一节:FastAPI入门一、FastAPI框架介绍什么是ASGI服务(WSGI)二、FastAP