Cesium虚线圆

封装的方法

js 复制代码
import * as Cesium from 'cesium'

export interface DashedCircleOptions {
  width?: number
  segments?: number
  color?: Cesium.Color
  gapColor?: Cesium.Color
  dashLength?: number
  dashPattern?: number
  height?: number
}

export function addDashedCircle (
  viewer: Cesium.Viewer,
  lon: number,
  lat: number,
  radiusMeters: number,
  options: DashedCircleOptions = {}
): Cesium.Primitive | undefined {
  if (!viewer || !Number.isFinite(lon) || !Number.isFinite(lat) || !Number.isFinite(radiusMeters)) return

  const width = options.width ?? 2
  const segments = options.segments ?? 64
  const color = options.color ?? Cesium.Color.YELLOW
  const gapColor = options.gapColor ?? Cesium.Color.TRANSPARENT
  const dashLength = options.dashLength ?? 16.0
  const dashPattern = options.dashPattern ?? 255.0
  const height = options.height ?? 0

  const earthRadius = 6378137
  const latRad = Cesium.Math.toRadians(lat)

  const positions: Cesium.Cartesian3[] = []
  for (let k = 0; k <= segments; k++) {
    const a = (Math.PI * 2 * k) / segments
    const dx = Math.cos(a) * radiusMeters
    const dy = Math.sin(a) * radiusMeters
    const cLat = lat + (dy / earthRadius) * (180 / Math.PI)
    const cLon = lon + (dx / (earthRadius * Math.cos(latRad))) * (180 / Math.PI)
    positions.push(Cesium.Cartesian3.fromDegrees(cLon, cLat, height))
  }

  const polylineGeometry = new Cesium.PolylineGeometry({
    positions,
    width,
    vertexFormat: Cesium.PolylineMaterialAppearance.VERTEX_FORMAT,
    arcType: Cesium.ArcType.NONE,
  })

  const primitive = viewer.scene.primitives.add(new Cesium.Primitive({
    geometryInstances: new Cesium.GeometryInstance({
      geometry: polylineGeometry,
    }),
    appearance: new Cesium.PolylineMaterialAppearance({
      material: new Cesium.Material({
        fabric: {
          type: 'PolylineDash',
          uniforms: {
            color,
            gapColor,
            dashLength,
            dashPattern,
          },
        },
      }),
    }),
    asynchronous: true,
  }))

  return primitive
}

调用

js 复制代码
    // 在目标位置绘制虚线圆
    addDashedCircle(viewer, newLon, newLat, 7000, {
      width: 2,
      segments: 128,
      color: Cesium.Color.CYAN,
      gapColor: Cesium.Color.TRANSPARENT,
      dashLength: 16,
      dashPattern: 255,
    })
相关推荐
allenjiao2 天前
WebGPU vs WebGL:WebGPU什么时候能完全替代WebGL?Web 图形渲染的迭代与未来
前端·图形渲染·webgl·threejs·cesium·webgpu·babylonjs
整点可乐7 天前
关于cesium的primitive的modelMatrix的应用
前端·javascript·cesium
GIS遥遥8 天前
Cesium进阶教程(2)|基于 Cesium 后处理Post Processing的图形绘制(上)
cesium·gis开发·webgis开发
幸会同学9 天前
在Cesium中实现飘动的红旗
javascript·three.js·cesium
落霞的思绪9 天前
Cesium里的postProcessStages实现暗黑样式的天地图
前端·gis·cesium
GIS兵墩墩12 天前
C1 ——cesium加载天地图瓦片
cesium·天地图
我是ed.13 天前
vue2 使用 cesium 展示 TLE 星历数据
vue.js·cesium
GisCoder17 天前
Cesium教程(9)---编辑Entity图形控制点、拖拽Entity移动、删除Entity
webgl·cesium
GISBox17 天前
BIM+GIS协同:RVT文件转3DTiles的技术路径与场景落地
cesium·3dtiles·gisbox·服务分发·gis server·切片转换·rvt
GISBox18 天前
高斯泼溅转3DTiles:GISBox高效转换全流程指南
免费·cesium·ply·3dtiles·高斯泼溅·gisbox·切片转换