ceisum实现动态立体墙上下循环动画,颜色逐渐透明

2024-05-25 05:44

本文主要是介绍ceisum实现动态立体墙上下循环动画,颜色逐渐透明,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

创建一个AnimationWall.js

export default class AnimationWall {    constructor(viewer) {    this.viewer = viewer;    this.animationDirection = 1; // 1表示向上,-1表示向下    }    add(positions) {    const maximumHeights = Array(positions.length / 3).fill(6000);    const halfHeights = maximumHeights.map(height => height / 3); // 最大高度的一半  const minimumHeights = Array(positions.length / 3).fill(600); // 假设这是墙壁的基础高度  positions = Cesium.Cartesian3.fromDegreesArrayHeights(positions);    let dayMaximumHeights = Array(maximumHeights.length).fill(minimumHeights[0]); // 初始化为最小值    // 创建一个函数来处理动画    function animateWallHeights() {    // 创建一个新的数组来存储新的最大高度值    const newDayMaximumHeights = dayMaximumHeights.map((height, index) => {    // 计算新的高度    height += maximumHeights[index] * 0.01 * this.animationDirection;    // 检查是否到达边界,并改变方向    if (height > maximumHeights[index]) {    height = maximumHeights[index];    this.animationDirection = -1; // 到达最大高度,开始下降    } else if (height < halfHeights[index]) {    height = halfHeights[index];    this.animationDirection = 1; // 到达最大高度的一半,开始上升    }    return height;    }, this);    // 更新dayMaximumHeights以准备下一次回调    dayMaximumHeights = newDayMaximumHeights;    // 返回新的最大高度数组    return newDayMaximumHeights;    }    // 添加墙壁到Cesium Viewer  this.viewer.entities.add({    wall: {    positions,    maximumHeights: new Cesium.CallbackProperty(() => animateWallHeights.call(this), false),    minimumHeights,    material: new Cesium.WallDiffuseMaterialProperty({  color: Cesium.Color.fromCssColorString("rgba(0,255,255,0.3)")  })  }    });    }    
}

页面里面引用这个js,调取这个 将坐标传入,我的是三维坐标xyz所以Array(positions.length / 3),二维改成2就行了,墙体颜色是逐渐透明的,效果是从一半才开始往上动画,不是从底部开始的

new AnimationWall(Map3D.viewer).add(coordinates);

这篇关于ceisum实现动态立体墙上下循环动画,颜色逐渐透明的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL中查找重复值的实现

《MySQL中查找重复值的实现》查找重复值是一项常见需求,比如在数据清理、数据分析、数据质量检查等场景下,我们常常需要找出表中某列或多列的重复值,具有一定的参考价值,感兴趣的可以了解一下... 目录技术背景实现步骤方法一:使用GROUP BY和HAVING子句方法二:仅返回重复值方法三:返回完整记录方法四:

IDEA中新建/切换Git分支的实现步骤

《IDEA中新建/切换Git分支的实现步骤》本文主要介绍了IDEA中新建/切换Git分支的实现步骤,通过菜单创建新分支并选择是否切换,创建后在Git详情或右键Checkout中切换分支,感兴趣的可以了... 前提:项目已被Git托管1、点击上方栏Git->NewBrancjsh...2、输入新的分支的

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

java实现docker镜像上传到harbor仓库的方式

《java实现docker镜像上传到harbor仓库的方式》:本文主要介绍java实现docker镜像上传到harbor仓库的方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 前 言2. 编写工具类2.1 引入依赖包2.2 使用当前服务器的docker环境推送镜像2.2

C++20管道运算符的实现示例

《C++20管道运算符的实现示例》本文简要介绍C++20管道运算符的使用与实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录标准库的管道运算符使用自己实现类似的管道运算符我们不打算介绍太多,因为它实际属于c++20最为重要的

Java easyExcel实现导入多sheet的Excel

《JavaeasyExcel实现导入多sheet的Excel》这篇文章主要为大家详细介绍了如何使用JavaeasyExcel实现导入多sheet的Excel,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录1.官网2.Excel样式3.代码1.官网easyExcel官网2.Excel样式3.代码

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机