Cesium在线绘制PolyLine折线

使用Cesium.CallbackProperty可以实时更改Geometry.position等参数,从而达到绘制的效果。

1.封装PolyLine对象
var PolyLinePrimitive = (function(){
    function _(positions){
        this.options = {
            polyline : {
                show : true,
                positions : [],
                material : Cesium.Color.CORNFLOWERBLUE,
                width : 5
            }
        };
        this.positions = positions;
        this._init();
    }

    _.prototype._init = function(){
        var _self = this;
        var _update = function(){
            return _self.positions;
        };
        //实时更新polyline.positions
        this.options.polyline.positions = new Cesium.CallbackProperty(_update,false);
        viewer.entities.add(this.options);
    };

    return _;
})();

2.初始化
var handler = new Cesium.ScreenSpaceEventHandler(scene.canvas);
var positions = [];
var poly = undefined;

3.鼠标监听事件
handler.setInputAction(function(movement){
    var cartesian = scene.camera.pickEllipsoid(movement.position,scene.globe.ellipsoid);
    if(positions.length == 0) {
        positions.push(cartesian.clone());
    }
    positions.push(cartesian);
},Cesium.ScreenSpaceEventType.LEFT_CLICK);

handler.setInputAction(function(movement){
    var cartesian = scene.camera.pickEllipsoid(movement.endPosition,scene.globe.ellipsoid);
    if(positions.length >= 2){
        if (!Cesium.defined(poly)) {
            poly = new PolyLinePrimitive(positions);
        }else{
            positions.pop();
            cartesian.y += (1 + Math.random());
            positions.push(cartesian);
        }
    }
},Cesium.ScreenSpaceEventType.MOUSE_MOVE);

handler.setInputAction(function(movement){
    handler.destroy();
},Cesium.ScreenSpaceEventType.LEFT_DOUBLE_CLICK);





### 在 Cesium 中添加 Polyline 实体的方法及常用参数 在 Cesium 中,`Polyline` 是一种用于表示三维空间中折线的实体类型。以下详细说明了如何添加 `Polyline` 实体以及其常用的参数配置。 #### 添加 Polyline 实体的方法 通过 `viewer.entities.add` 方法可以向场景中添加一个 `Polyline` 实体。以下是基本代码示例: ```javascript let polylineEntity = viewer.entities.add({ polyline: { positions: Cesium.Cartesian3.fromDegreesArray([ 116.404, 39.915, // 起点经度、纬度 117.20, 39.13 // 终点经度、纬度 ]), width: 5, // 线条宽度 material: Cesium.Color.RED // 线条颜色 } }); ``` #### 常用参数详解 1. **positions** 定义折线的顶点位置数组,支持多种格式: - 使用 `Cesium.Cartesian3.fromDegreesArray` 将经纬度数组转换为笛卡尔坐标数组[^2]。 - 示例:`Cesium.Cartesian3.fromDegreesArray([lon1, lat1, lon2, lat2])`。 2. **width** 设置线条的宽度,单位为像素。例如:`width: 5`。 3. **material** 定义线条的材质,通常使用 `Cesium.Color` 来指定颜色。也可以使用复杂的材质属性,如渐变色或虚线效果: - 固定颜色:`material: Cesium.Color.RED.withAlpha(0.5)`。 - 虚线效果:`material: new Cesium.PolylineDashMaterialProperty({ color: Cesium.Color.YELLOW })`[^3]。 4. **clampToGround** 控制线条是否贴地显示。设置为 `true` 时,线条将沿着地形表面绘制: - 示例:`clampToGround: true`。 5. **depthFailMaterial** 当启用 `clampToGround` 时,定义深度测试失败时的材质。通常与 `material` 参数配合使用以实现更复杂的视觉效果。 6. **show** 控制实体是否可见。默认值为 `true`,可以通过设置 `false` 隐藏实体。 #### 示例代码 以下是一个完整的示例,展示如何创建一条带有虚线效果且贴地显示的 `Polyline`: ```javascript let polylineEntity = viewer.entities.add({ polyline: { positions: Cesium.Cartesian3.fromDegreesArray([ 116.404, 39.915, 117.20, 39.13 ]), width: 3, material: new Cesium.PolylineDashMaterialProperty({ color: Cesium.Color.BLUE, gapColor: Cesium.Color.TRANSPARENT }), clampToGround: true } }); ``` #### 注意事项 - 如果需要动态更新 `Polyline` 的顶点位置,可以通过修改 `entity.polyline.positions` 属性来实现。 - 使用 `viewer.entities.removeAll()` 可以清除所有已添加的实体。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

低热量薯条

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值