cesium entities 图形绘制

1.正方形绘制 box 方法

官网链接: https://cesium.com/learn/cesiumjs/ref-doc/BoxGraphics.html

box中属性
属性含义值
outline设置指定box是否有轮廓的Property 默认
outlineColor轮廓线颜色
material设置颜色
dimensions设置形状
fill设置填充色显示隐藏
distanceDisplayCondition距相机多远的距离处显示或隐藏
shadowsShadowMode.DISABLED设置投影

示例代码如下

viewer.entities.add({
            name : 'Red box',
            position: Cesium.Cartesian3.fromDegrees(116.39, 39.9),
            box: {
                dimensions: new Cesium.Cartesian3(30000.0, 30000.0, 30000),//设置长宽高
                material : Cesium.Color.GREENYELLOW.withAlpha(0.5), //设置颜色
                outline : true,//设置指定box是否有轮廓的Property 默认false 
                outlineColor : Cesium.Color.BLACK, //设置轮廓线
                //fill:false,//取消填充
                //distanceDisplayCondition: new Cesium.DistanceDisplayCondition( 0.0, 5.5e6 ),
            }
        });

在这里插入图片描述

2.圆角体绘制 corridor 方法

官网链接: https://cesium.com/learn/cesiumjs/ref-doc/CorridorGraphics.html

corridor 中属性
属性含义值
cornerType直角样式: Cesium.CornerType.BEVELED 。 圆角样式: Cesium.CornerType.ROUNDED
extrudedHeightnumber 类型 体积厚度高度
height离地面高度
outline设置指定corridor 是否有轮廓的Property 默认
outlineColor轮廓线颜色
outlineWidth轮廓线宽度
fill设置填充色显示隐藏
distanceDisplayConditionnew Cesium.DistanceDisplayCondition( 0.0, 5.5e6 )距相机多远的距离处显示或隐藏
zIndex图层的优先级
shadowsShadowMode.DISABLED设置投影
showtrue或false实体显示隐藏(动态改变直接改变show就可以)

示例代码如下

viewer.entities.add({
            name : 'Red box with black outline',
            corridor: {
                positions: Cesium.Cartesian3.fromDegreesArray([
                    104.0, 39,
                    102.0, 39,
                    102.0, 35,
                  ]),
                  height: 200000.0,
                  extrudedHeight: 200000.0,//厚度
                  width: 100000.0,
                  cornerType: Cesium.CornerType.ROUNDED ,//Cesium.CornerType.BEVELED,
                  material: Cesium.Color.BLUE.withAlpha(0.5),
                  outline: true, // height or extrudedHeight must be set for outlines to display
                  outlineColor: Cesium.Color.WHITE,
            }
        });

在这里插入图片描述

3.立体线绘制 polylineVolume方法

官网链接: https://cesium.com/learn/cesiumjs/ref-doc/PolylineVolumeGraphics.html

polylineVolume中属性
属性含义值
cornerType直角样式: Cesium.CornerType.BEVELED 。 圆角样式: Cesium.CornerType.ROUNDED
outline设置指定corridor 是否有轮廓的Property 默认
outlineColor轮廓线颜色
outlineWidth轮廓线宽度
fill设置填充色显示隐藏
distanceDisplayConditionnew Cesium.DistanceDisplayCondition( 0.0, 5.5e6 )距相机多远的距离处显示或隐藏
shape设置形状
shadowsShadowMode.DISABLED设置投影
showtrue或false实体显示隐藏(动态改变直接改变show就可以)

示例代码如下

viewer.entities.add({
 polylineVolume: {
   positions: Cesium.Cartesian3.fromDegreesArrayHeights([
     113.39, 35.0, 0.0,
     118.39, 37.0, 0.0,
     119.39, 30.0, 0.0,
   ]),
   shape: computeStar(4, 1000, 30000),
   cornerType: Cesium.CornerType.MITERED,
   material: Cesium.Color.BLUE,
 },
});
function computeStar(arms, rOuter, rInner) {
 var angle = Math.PI / arms;
 var length = 2 * arms;
 var positions = new Array(length);
 for (var i = 0; i < length; i++) {
   var r = i % 2 === 0 ? rOuter : rInner;
   positions[i] = new Cesium.Cartesian2(
     Math.cos(i * angle) * r,
     Math.sin(i * angle) * r
   );
 }
 return positions;
}
function computeCircle(radius) {
 var positions = [];
 for (var i = 0; i < 360; i++) {
   var radians = Cesium.Math.toRadians(i);
   positions.push(
     new Cesium.Cartesian2(
       radius * Math.cos(radians),
       radius * Math.sin(radians)
     )
   );
 }
 return positions;
}

在这里插入图片描述

4.加载圆柱体圆锥体 cylinder方法

官网地址:https://cesium.com/learn/cesiumjs/ref-doc/CylinderGraphics.html

cylinder中属性
属性含义值
bottomRadiusnumber 低部半径大小
topRadiusnumber 顶部半径大小(半径为“0”时为圆锥体)
lengthnumber 高度
material设置材质
numberOfVerticalLinesnumber 沿轮廓的周长绘制的垂直线数
outline设置指定corridor 是否有轮廓的Property 默认
outlineColor轮廓线颜色
outlineWidth轮廓线宽度
fill设置填充色显示隐藏
distanceDisplayConditionnew Cesium.DistanceDisplayCondition( 0.0, 5.5e6 )距相机多远的距离处显示或隐藏
shadowsShadowMode.DISABLED设置投影
showtrue或false实体显示隐藏(动态改变直接改变show就可以)

示例代码

viewer.entities.add({
            position: Cesium.Cartesian3.fromDegrees(113.39, 40.0, 100000.0),
            cylinder: {
                length: 200000.0,
                topRadius: 55000.0,//圆柱顶部大小
                 // topRadius: 0.0,//圆柱顶部大小
                bottomRadius: 55000.0,//圆柱低部大小
                outline: true,
                outlineColor: Cesium.Color.WHITE,
                outlineWidth: 4,
                material: Cesium.Color.YELLOW.withAlpha(0.9),
            },
        });

在这里插入图片描述

5.加载立体墙自带呼吸灯效果 wall方法

官网地址:https://cesium.com/learn/cesiumjs/ref-doc/WallGraphics.html

wall中属性
属性含义值
material设置材质
maximumHeights用于墙顶的高度数组,而不是每个位置的高度
minimumHeights用于墙底的高度数组
outline设置指定corridor 是否有轮廓的Property 默认
outlineColor轮廓线颜色
outlineWidth轮廓线宽度
fill设置填充色显示隐藏
distanceDisplayConditionnew Cesium.DistanceDisplayCondition( 0.0, 5.5e6 )距相机多远的距离处显示或隐藏
shadowsShadowMode.DISABLED设置投影
showtrue或false实体显示隐藏(动态改变直接改变show就可以)

示例代码

var alp = 1;
        var num = 0
        this.viewer.entities.add({
            name: "Green wall from surface with outline",
            wall: {
              positions: Cesium.Cartesian3.fromDegreesArrayHeights([
                -107.0, 43.0, 100000.0,
                -97.0, 43.0, 100000.0, 
                -97.0, 40.0, 100000.0,
                -107.0, 40.0, 100000.0,
                -107.0, 43.0, 100000.0,
              ]),
              material: new Cesium.ImageMaterialProperty({
                image:require("../assets/tu.jpg"),
                transparent:true,
                color:new Cesium.CallbackProperty(function () {
                        if ((num % 2) === 0){
                            alp -=0.05;
                        }else {
                            alp +=0.05;
                        }

                        if (alp <= 0.3){
                            num++;
                        }else if (alp >= 1){
                            num++;
                        }
                        return  Cesium.Color.WHITE.withAlpha(alp)
                        //entity的颜色透明 并不影响材质,并且 entity也会透明
                    },false)
                }),

              outline: true,
            }
        });

在这里插入图片描述

  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

GIS-CL

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

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

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

打赏作者

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

抵扣说明:

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

余额充值