【Cesium入门教程】第七课:Primitive图元

Cesium丰富的空间数据可视化API分为两部分:primitive API面向三维图形开发者,更底层一些。

Entity API是数据驱动更高级一些。

javascript 复制代码
// entity
// 调用方便,封装完美
// 是基于primitive的封装

// primitive
// 更接近底层
// 可以绘制高级图形
// 由Geometry(几何形状)、(Appearance)外观组成
javascript 复制代码
const primitive = new Cesium.Primitive({
  geometryInstances: new Cesium.GeometryInstance({
    geometry: new Cesium.EllipseGeometry({
      center: Cesium.Cartesian3.fromDegrees(-100.0, 20.0),
      semiMinorAxis: 500000.0,
      semiMajorAxis: 1000000.0,
      rotation: Cesium.Math.PI_OVER_FOUR,
      vertexFormat: Cesium.VertexFormat.POSITION_AND_ST
    }),
  }),
  appearance: new Cesium.EllipsoidSurfaceAppearance({
    material: Cesium.Material.fromType('Stripe')
  })
})
viewer.scene.primitives.add(primitive);

组合图形

javascript 复制代码
<h1 id="m7WFT">组合图形</h1>
```javascript
const rectangleInstance = new Cesium.GeometryInstance({
  geometry: new Cesium.RectangleGeometry({
    rectangle: Cesium.Rectangle.fromDegrees(-140.0, 30.0, -100.0, 40.0),
    vertexFormat: Cesium.PerInstanceColorAppearance.VERTEX_FORMAT
  }),
  id: 'rectangle',
  attributes: {
    color: new Cesium.ColorGeometryInstanceAttribute(0.0, 1.0, 1.0, 0.5)
  }
});

const ellipsoidInstance = new Cesium.GeometryInstance({
  geometry: new Cesium.EllipsoidGeometry({
    radii: new Cesium.Cartesian3(500000.0, 500000.0, 1000000.0),
    vertexFormat: Cesium.VertexFormat.POSITION_AND_NORMAL
  }),
  modelMatrix: Cesium.Matrix4.multiplyByTranslation(Cesium.Transforms.eastNorthUpToFixedFrame(
    Cesium.Cartesian3.fromDegrees(-95.59777, 40.03883)), new Cesium.Cartesian3(0.0, 0.0, 500000.0), new Cesium.Matrix4()),
  id: 'ellipsoid',
  attributes: {
    color: Cesium.ColorGeometryInstanceAttribute.fromColor(Cesium.Color.AQUA)
  }
});

viewer.scene.primitives.add(new Cesium.Primitive({
  geometryInstances: [rectangleInstance, ellipsoidInstance],
  appearance: new Cesium.PerInstanceColorAppearance()
}));

点击事件

javascript 复制代码
<h1 id="qr6o4">点击事件:</h1>
<h3 id="XXD1c">添加地形图层后去画点</h3>
```javascript
let viewer = new Cesium.Viewer('cesiumContainer', {
  terrainProvider: Cesium.createWorldTerrain()
})

let handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas);
handler.setInputAction((event) => {
  //返回一个笛卡尔坐标
  let position = viewer.scene.pickPosition(event.position);
  //如果有这个坐标
  if (Cesium.defined(position)) {
    console.log(position)
    viewer.entities.add({
      position: position,
      point: {
        color: Cesium.Color.BLUE,
        pixelSize: 20,
      },
    })
    console.log(viewer.entities)
  }
}, Cesium.ScreenSpaceEventType.LEFT_CLICK);

事件注销

javascript 复制代码
handler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_CLICK)//移除左键点击事件

申明变量

javascript 复制代码
let pickModel

鼠标移动事件

javascript 复制代码
//添加建筑物
const city = viewer.scene.primitives.add(
    new Cesium.Cesium3DTileset({
        url: Cesium.IonResource.fromAssetId(75343),
    })
);
viewer.flyTo(city)

let handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas);
handler.setInputAction((event) => {
    //拾取模型
    const pick = viewer.scene.pick(event.endPosition);
    if (pick) {
        if (pickModel) {
            pickModel.color = Cesium.Color.WHITE;
        }
        pick.color = Cesium.Color.ORANGERED;
        pickModel = pick;
    }
}, Cesium.ScreenSpaceEventType.MOUSE_MOVE);

注销事件

javascript 复制代码
handler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_CLICK)//移除左键点击事件
相关推荐
歪歪10021 小时前
详细介绍一下“集中同步+分布式入库”方案的具体实现步骤
开发语言·前端·分布式·后端·信息可视化
2503_928411561 天前
11.5 包和包管理器
数据库·arcgis·node.js·编辑器
极造数字2 天前
从EMS看分布式能源发展:挑战与机遇并存
人工智能·分布式·物联网·信息可视化·能源·制造
前端_Danny2 天前
使用 ECharts + ECharts-GL 生成 3D 环形图
3d·信息可视化·echarts
受伤的僵尸2 天前
为什么Arcgis/Qgis里我的图是扁的
arcgis
weixin_贾2 天前
ArcGIS+ENVI实战:从零制作生态影响评价专题图(以植被类型与土壤侵蚀为例)
arcgis·土地利用·dem·水文分析·土壤侵蚀·arcgis栅格·envi遥感影像
形宙数字2 天前
【形宙数字】MANGOLD INTERACT 行为观察分析系统-行为观察统计分析-人类行为学研究-行为逻辑
信息可视化·数据分析·行为观察分析系统·行为观察统计分析·人类行为学研究·行为逻辑·形宙数字
TG:@yunlaoda360 云老大2 天前
火山引擎数智平台VeDI重磅发布“AI助手”:以大模型驱动数据飞轮,赋能非技术人员高效“看数、用数”
人工智能·信息可视化·火山引擎
GIS开发特训营3 天前
WebGIS开发智慧校园(14)地图控件的添加
智慧校园·gis·gis开发·webgis
Doc.S3 天前
【保姆级教程】在AutoDL容器中部署EGO-Planner,实现无人机动态避障规划
人工智能·python·信息可视化·机器人