cesium如何获取primitive图元上的坐标
时间: 2023-02-06 12:57:33 浏览: 262
Cesium是一个开源的虚拟地球引擎,可以通过JavaScript在浏览器中渲染3D地球。Primitive图元是Cesium中用于渲染3D几何形状的基本单元。
要获取primitive图元上的坐标,可以使用Cesium中的`getGeometryInstanceAttributes`方法。这个方法接受一个`geometry`参数,表示要获取坐标的图元,并返回一个包含图元坐标的对象。
例如,如果你想获取一个名为`box`的立方体图元上的坐标,你可以这样做:
```javascript
var box = viewer.scene.primitives.add(new Cesium.BoxGeometry({
vertexFormat : Cesium.VertexFormat.POSITION_ONLY,
dimensions : new Cesium.Cartesian3(1000000.0, 1000000.0, 500000.0)
}));
var attributes = box.getGeometryInstanceAttributes('box');
console.log(attributes);
```
这将输出包含立方体图元坐标的对象。
注意:在调用`getGeometryInstanceAttributes`方法之前,你需要确保图元已经被添加到场景中。
相关问题
cesium 判断primitive与笛卡尔坐标相交
在Cesium中,可以使用GeometryPipeline类的`computeDistanceToIntersection`方法来判断一个primitive与笛卡尔坐标是否相交。以下是一个示例代码:
```javascript
var viewer = new Cesium.Viewer('cesiumContainer');
// 创建一个 primitive,例如矩形
var rectangle = new Cesium.RectanglePrimitive({
rectangle: Cesium.Rectangle.fromDegrees(-100.0, 30.0, -90.0, 40.0),
material: Cesium.Material.fromType(Cesium.Material.ColorType)
});
viewer.scene.primitives.add(rectangle);
// 笛卡尔坐标
var position = Cesium.Cartesian3.fromDegrees(-95.0, 35.0);
// 判断 primitive 是否与笛卡尔坐标相交
var intersection = Cesium.GeometryPipeline.computeDistanceToIntersection(rectangle.geometry, position);
if (intersection.distance === 0) {
console.log("相交");
} else {
console.log("不相交");
}
```
在上述代码中,我们首先创建了一个矩形的primitive,并将其添加到场景中。然后,我们定义了一个笛卡尔坐标,并使用`computeDistanceToIntersection`方法判断primitive与该坐标是否相交。最后,根据判断结果输出相应的信息。
请注意,这个方法只适用于计算与primitive的几何形状相交的情况,如果要判断与其他类型的primitive相交,可能需要使用其他的方法。
cesium 判断primitive与经纬度坐标相交
在Cesium中,可以使用Entity API中的`computePolygonGroundIntersection`方法来判断一个primitive与经纬度坐标是否相交。以下是一个示例代码:
```javascript
var viewer = new Cesium.Viewer('cesiumContainer');
// 创建一个 primitive,例如矩形
var rectangle = new Cesium.RectanglePrimitive({
rectangle: Cesium.Rectangle.fromDegrees(-100.0, 30.0, -90.0, 40.0),
material: Cesium.Material.fromType(Cesium.Material.ColorType)
});
viewer.scene.primitives.add(rectangle);
// 经纬度坐标
var position = Cesium.Cartographic.fromDegrees(-95.0, 35.0);
// 判断 primitive 是否与经纬度坐标相交
var intersection = Cesium.PolygonGeometryLibrary.computePolygonGroundIntersection(rectangle.rectangle, position);
if (intersection) {
console.log("相交");
} else {
console.log("不相交");
}
```
在上述代码中,我们首先创建了一个矩形的primitive,并将其添加到场景中。然后,我们定义了一个经纬度坐标,并使用`computePolygonGroundIntersection`方法判断primitive与该坐标是否相交。最后,根据判断结果输出相应的信息。
请注意,这个方法只适用于计算与地表相交的情况,如果要判断与其他类型的primitive相交,可能需要使用其他的方法。
阅读全文