【Cesium】实现卷帘对比

一、创建滑块

<style>
    @import url(../Build/CesiumUnminified/Widgets/widgets.css);
    @import url(./Sandcastle/templates/bucket.css);

    #slider {
      position: absolute;
      left: 50%;
      top: 0px;
      background-color: #d3d3d3;
      width: 5px;
      height: 100%;
      z-index: 9999;
    }

    #slider:hover {
      cursor: ew-resize;
    }
  </style>
<body>
<div id="cesiumContainer" class="fullSize">
    <div id="slider"></div>
</div>
</body>

 二、实现卷帘对比

    const viewer = new Cesium.Viewer('cesiumContainer');
    // 加载Cesium3DTileset切片模型
    const left = new Cesium.Cesium3DTileset({ url: Cesium.IonResource.fromAssetId(2367681) });
    viewer.scene.primitives.add(left);
    left.splitDirection = Cesium.SplitDirection.LEFT;
    viewer.zoomTo(left);

    // 创建Osm对比模型
    const right = Cesium.createOsmBuildings();
    viewer.scene.primitives.add(right);
    right.splitDirection = Cesium.SplitDirection.RIGHT;

    // 获取滑块和初始化位置
    const slider = document.getElementById("slider");
    viewer.scene.splitPosition = slider.offsetLeft / slider.parentElement.offsetWidth;

    const handler = new Cesium.ScreenSpaceEventHandler(slider);
    let moveActive = false;
    
    // 定义滑块位置和场景内容
    function move(movement) {
        if (!moveActive) {
            return;
        }

        const relativeOffset = movement.endPosition.x;
        const splitPosition = (slider.offsetLeft + relativeOffset) / slider.parentElement.offsetWidth;
        slider.style.left = `${100.0 * splitPosition}%`;
        viewer.scene.splitPosition = splitPosition;
    }

    // 鼠标滑动更新滑块位置和场景内容
    handler.setInputAction(move, Cesium.ScreenSpaceEventType.MOUSE_MOVE);

    // 鼠标按下和拖动行为 触发move事件
    handler.setInputAction(function () {
        moveActive = true;
    }, Cesium.ScreenSpaceEventType.LEFT_DOWN);

    // 鼠标放开释放move事件
    handler.setInputAction(function () {
        moveActive = false;
    }, Cesium.ScreenSpaceEventType.LEFT_UP);

  • 8
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Cesium是一种开源的虚拟地球浏览器,可以用于呈现三维地球上的地理空间数据。Cesium通过其强大的图形渲染引擎和开放的插件系统,可以实现流动效果。 要实现流动,首先需要将动态数据加载到Cesium中。Cesium支持各种数据格式,如GeoJSON、KML、Shapefile等,可以通过加载这些数据文件来获取实时或历史地理空间数据。数据可以包含地球表面上的对象,例如河流、风向、海洋流等。将这些数据加载到Cesium中后,即可在三维地球上呈现流动效果。 在数据加载后,可以使用Cesium提供的API来实现流动效果。例如,可以使用Cesium的动画功能来控制时间流逝,并在地球上移动对象。这样,地球上的河流、风向箭头或海洋流线就可以随着时间的推移动态展示其流动状态。通过调整时间流逝的速度和其他动画参数,可以实现不同的流动效果,从而更好地展示地理空间数据。 此外,Cesium还支持自定义流动效果。开发人员可以使用Cesium的开放插件系统创建自定义的流动效果。通过使用Cesium的图形渲染引擎和JavaScript编程接口,可以实现各种各样的流动效果,满足不同的需求和创意。 总之,Cesium通过其强大的图形渲染引擎和开放的插件系统,可以实现流动效果。通过加载动态数据,并使用Cesium的动画功能或自定义插件,可以在三维地球上展示各种流动状态的地理空间数据。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

鱼遇雨愈愉

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

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

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

打赏作者

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

抵扣说明:

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

余额充值