Does the point of Entity become smaller after switching to Billboard?

cesium version: 1.119

sample code:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <script src="https://cdn.bootcdn.net/ajax/libs/cesium/1.119.0/Cesium.js"></script>
  <link href="https://cdn.bootcdn.net/ajax/libs/cesium/1.119.0/Widgets/widgets.css" rel="stylesheet">
</head>
<body>
  <div id="map"></div>
</body>

<script>
  
  let viewer = new Cesium.Viewer(document.getElementById('map'), {
    // 是否创建动画小器件,左下角仪表
    animation: false,
    // 是否显示图层选择器
    baseLayerPicker: false,
    // 是否显示全屏按钮
    fullscreenButton: false,
    // 是否显示geocoder小器件,右上角查询按钮
    geocoder: false,
    // 是否显示Home按钮
    homeButton: false,
    // 是否显示信息框
    infoBox: false,
    // 是否显示3D/2D选择器
    sceneModePicker: false,
    // 如果设置为true,则所有几何图形以3D模式绘制以节约GPU资源
    scene3DOnly: true,
    // 是否显示选取指示器组件
    selectionIndicator: false,
    // 是否显示时间轴
    timeline: false,
    // 是否显示右上角的帮助按钮
    navigationHelpButton: false,
    // 将图层选择的控件关掉,才能添加其他影像数据
    baselLayerPicker: false,
    // 是否显示背影
    shadows: false,
    shouldAnimate: false,
    vrButton: false,
    baseLayer: new Cesium.ImageryLayer(new Cesium.UrlTemplateImageryProvider({ // 设置底图
      url: 'https://abd.com',
    }))
  })

  viewer.camera.setView({ destination: Cesium.Cartesian3.fromDegrees(102.72355497615297, 25.035745367219242, 220000) });

  let point= {
    "heightReference": 3,
    "color": Cesium.Color.RED,
    "pixelSize": 100
  }
  let billboard = {
    "heightReference": 3,
    "image": "",
    "width": 20,
    "height": 20,
    "scale": 1
  }

  // 添加点
  let entity = viewer.entities.add({
    position: Cesium.Cartesian3.fromDegrees(102.62355497615297, 25.035745367219242),
    point
  });


  setTimeout(() => {
    entity.point = undefined;
    entity.billboard = billboard;

    setTimeout(()=>{
      entity.billboard = undefined;
      entity.point = point;
    }, 3000)
  }, 3000);



</script>

<style>
  html,body,#map{
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    overflow: hidden;
  }
</style>

</html>
  1. Create a point
  2. Change the point to billboard after 3 seconds
  3. Change to point after 3 seconds
  4. At this point, the size of the dots has decreased, and any additional dots added will also be small
  • May I ask what caused the point to become smaller?

After I modified the width and height of the billboard, the point also changed

Hi @mcck ,
Thanks for your post and being part of the Cesium community.

It sounds like you have a potential resolution to your issue. Another approach you could consider is creating separate entities for the point content and billboard content, and alternate showing them according to your logic. This may simplify your approach from needing to update the size when switching from one to the other.

Please let us know what solution ends up working best for you and if you have further questions.
Best,
Luke