解读——SuperMap iClient3D for Cesium使用柱体截面绘制河流

原文参考

SuperMap iClient3D for Cesium绘制河流(二)_cesium polylinevolume 管道流向添加-CSDN博客

javascript 复制代码
river = viewer.entities.add({
  name : 'river',
  polylineVolume : {
    positions: new Cesium.Cartesian3.fromDegreesArrayHeights(positions),  //节点坐标
    shape: computeCircle(150.0),  //截面形状
    material : new Cesium.PolylineTrailLinkMaterialProperty(Cesium.Color.SKYBLUE,10000),
    cornerType: Cesium.CornerType.MITERED,
  }
})

function computeCircle(radius) {  //设置截面长和宽的大小
  var positions = [];
  for(var i = 0; i < 180; i++) {
    let x = radius * Math.cos(Math.PI * 2 * i / 360); //宽度参数radius可传入进行控制
    let y = 0.1 * Math.sin(Math.PI * 2 * i / 360); //将高度尽可能设置小,达到面片效果
    positions.push(new Cesium.Cartesian2(x, y));
  }
  return positions;
}

将截面设置为面片模拟河流

computeCircle方法是生成一个圆形截面的顶点位置数组,用于创建多段线体积的截面形状。

以下是对其原理的几何角度解释:

首先,我们需要了解一些基本几何概念:-

圆的参数方程:在平面直角坐标系中,一个半径为r的圆可以由以下参数方程表示:

x = r * cos(θ)

y = r * sin(θ)

其中,(x, y)是圆上的一个点,θ是该点与圆心的连线与x轴正方向的夹角。

  • 弧度和角度的转换关系:

一个完整的圆周对应的角度是360度或2π弧度,因此,我们可以通过以下关系将角度转换为弧度:

弧度 = 角度 * (π / 180)

其中,π是圆周率。

现在,我们来解释代码中的计算过程:

javascript 复制代码
let x = radius * Math.cos(Math.PI * 2 * i / 360);
let y = 0.1 * Math.sin(Math.PI * 2 * i / 360);
  • Math.cos(Math.PI * 2 * i / 360):这里的`Math.cos()`函数计算给定角度的余弦值。我们将角度转换为弧度,使用了`Math.PI * 2 * i / 360`的方式。其中,`Math.PI * 2`表示一个完整的圆周对应的弧度,`i`是当前的角度,`360`是一个完整的圆周对应的角度。
  • -Math.sin(Math.PI * 2 * i / 360):这里的`Math.sin()`函数计算给定角度的正弦值。同样,我们将角度转换为弧度。
  • radius:这是传入的半径参数,用于控制截面的大小。通过将半径乘以余弦值,我们可以得到每个顶点在x轴上的坐标。
  • 0.1:将半径设为0.1,即将截面在y轴上的高度控制在一个较小的值,从而实现了截面的效果。
  • 循环变量i的范围是从0到180:这是因为我们希望生成一个半圆形的截面,而不是完整的圆形。

综上所述,通过使用圆的参数方程和给定的半径参数,我们可以计算出圆形截面的每个顶点的x和y坐标。这些坐标将用于创建多段线体积的截面形状。

相关推荐
小明爱吃瓜15 分钟前
AI IDE(Copilot/Cursor/Trae)图生代码能力测评
前端·ai编程·trae
水冗水孚17 分钟前
🚀四种方案解决浏览器地址栏预览txt文本乱码问题🚀Content-Type: text/plain;没有charset=utf-8
javascript·nginx·node.js
不爱说话郭德纲20 分钟前
🔥Vue组件的data是一个对象还是函数?为什么?
前端·vue.js·面试
绅士玖22 分钟前
JavaScript 中的 arguments、柯里化和展开运算符详解
前端·javascript·ecmascript 6
每天都想着怎么摸鱼的前端菜鸟24 分钟前
【uniapp】uniapp热更新WGT资源,简单的多环境WGT打包脚本
javascript·uni-app
GIS之路25 分钟前
OpenLayers 图层控制
前端
断竿散人25 分钟前
专题一、HTML5基础教程-http-equiv属性深度解析:网页的隐形控制中心
前端·html
星河丶25 分钟前
介绍下navigator.sendBeacon方法
前端
curdcv_po26 分钟前
🤸🏼🤸🏼🤸🏼兄弟们开源了,用ThreeJS还原小米SU7超跑!
前端
我是小七呦26 分钟前
😄我再也不用付费使用PDF工具了,我在Web上实现了一个PDF预览/编辑工具
前端·javascript·面试