【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)//移除左键点击事件
相关推荐
GIS学姐嘉欣1 天前
地信、测绘、遥感等专业免费学习网站推荐
学习·gis开发·webgis
CodeCraft Studio1 天前
【案例分享】如何利用图表控件TeeChart集成,实现可持续环境修复
信息可视化·图表控件·teechart·图表组件·图表工具·钻孔数据可视化·地质数据可视化
无心水1 天前
【Python实战进阶】2、Jupyter Notebook终极指南:为什么说不会Jupyter就等于不会Python?
python·jupyter·信息可视化·binder·google colab·python实战进阶·python工程化实战进阶
GISer_Jing1 天前
遥感图像分割:五大开源模型推荐
arcgis·开源
2501_941143731 天前
R语言统计分析与可视化实践分享:高效数据处理与图表展示优化经验
信息可视化
2***57421 天前
前端数据可视化应用
前端·信息可视化
Pocker_Spades_A2 天前
网易CodeWave进阶实战:基于CodeWave构建船舶信息可视化应用
信息可视化
汤姆yu2 天前
基于python大数据的小说数据可视化及预测系统
大数据·python·信息可视化
A***07172 天前
React数据可视化应用
前端·react.js·信息可视化
二川bro2 天前
数据可视化进阶:Python动态图表制作实战
开发语言·python·信息可视化