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

Cesium特效——城市白模的科技动效的各种效果

最终效果图如下:

实现方法:

步骤一:使用cesiumlib生产白模,格式为3dtiles

注意事项:采用其他方式可能导致白模贴地,从而导致不能实现该效果,例如把步骤二的服务地址改为Cesium Sandcastle 里的3dtiles服务,就不能实现效果图里的效果。原因是cesiumlib生成的白模服务本质上是错误的,是都在一个平面上。所以为保证精确度,场景需要小一些。

设置拉伸高度。

提交处理:

步骤二:设置样式(style)、customShader

导入3dtiles服务:

  const tileset = await Cesium.Cesium3DTileset.fromUrl("第一步生成的3dtiles数据发布的服务地址");viewer.scene.primitives.add(tileset);

设置样式:

const style = new Cesium.Cesium3DTileStyle({color: {conditions: [["${Floor} < 10.0", "color('#00356A')"], // 深蓝色["(${Floor} >= 10.0) && (${Floor} < 20.0)", "color('#0099FF')"], // 亮蓝色["(${Floor} >= 20.0) && (${Floor} < 30.0)", "color('#0066CC')"], // 电蓝色["(${Floor} >= 30.0) && (${Floor} < 60.0)", "color('#00FFFF')"], // 荧光蓝["${Floor} >= 60.0", "color('#0033CC')"], // 深蓝色],},});
tileset.style = style;

设置shader:

// 增加自定义shaderlet customShader = new Cesium.CustomShader({//PBR(基于物理的渲染)或 UNLIT,具体取决于所需的结果。lightingModel: Cesium.LightingModel.UNLIT,fragmentShaderText: `void fragmentMain(FragmentInput fsInput, inout czm_modelMaterial material) {float _baseHeight = 0.0; // 物体的基础高度,需要修改成一个合适的建筑基础高度float _heightRange = 30.0; // 高亮的范围(_baseHeight ~ _baseHeight + _heightRange) 默认是 0-60米float _glowRange = 300.0; // 光环的移动范围(高度)float vtxf_height = fsInput.attributes.positionMC.z-_baseHeight;float vtxf_a11 = fract(czm_frameNumber / 120.0) * 3.14159265 * 2.0;float vtxf_a12 = vtxf_height / _heightRange + sin(vtxf_a11) * 0.1;material.diffuse*= vec3(vtxf_a12, vtxf_a12, vtxf_a12);float vtxf_a13 = fract(czm_frameNumber / 120.0);float vtxf_h = clamp(vtxf_height / _glowRange, 0.0, 1.0);vtxf_a13 = abs(vtxf_a13 - 0.5) * 2.0;float vtxf_diff = step(0.005, abs(vtxf_h - vtxf_a13));material.diffuse += material.diffuse * (1.0 - vtxf_diff);}	 	`,});tileset.customShader = customShader;
}

http://www.lryc.cn/news/526322.html

相关文章:

  • VS Code i18n国际化组件代码code显示中文配置 i18n ally
  • C++ —— 智能指针 unique_ptr (上)
  • 技术 · 创作 · 生活 | 我的 2024 全面复盘
  • 表的增删改查(MySQL)
  • 【设计模式】JAVA 策略 工厂 模式 彻底告别switch if 等
  • 基于Springboot用axiospost请求接收字符串参数为null的解决方案
  • 最长递增——蓝桥杯
  • 【MFC】C++所有控件随窗口大小全自动等比例缩放源码(控件内字体、列宽等未调整) 20250124
  • C#标准Mes接口框架(持续更新)
  • 【Uniapp-Vue3】动态设置页面导航条的样式
  • SQL 递归 ---- WITH RECURSIVE 的用法
  • 期权帮|如何利用股指期货进行对冲套利?
  • INCOSE需求编写指南-第1部分:介绍
  • FFPlay命令全集合
  • Mono里运行C#脚本34—内部函数调用的过程
  • rust feature h和 workspace相关知识 (十一)
  • -bash: ./uninstall.command: /bin/sh^M: 坏的解释器: 没有那个文件或目录
  • 【Redis】Redis入门以及什么是分布式系统{Redis引入+分布式系统介绍}
  • C#高级:常用的扩展方法大全
  • Consul持久化配置报错1067---consul_start
  • 「 机器人 」扑翼飞行器控制策略浅谈
  • Qt信号与槽底层实现原理
  • QT QTableWidget控件 全面详解
  • Flutter_学习记录_基本组件的使用记录
  • 基于JAVA的微信点餐小程序设计与实现(LW+源码+讲解)
  • 计算机毕业设计hadoop+spark+hive民宿推荐系统 酒店推荐系统 民宿价格预测 酒店价格 预测 机器学习 深度学习 Python爬虫 HDFS集群
  • 亲测有效!解决PyCharm下PyEMD安装报错 ModuleNotFoundError: No module named ‘PyEMD‘
  • Gin 应用并注册 pprof
  • Jenkins 启动
  • 第20篇:Python 开发进阶:使用Django进行Web开发详解