Cesium 时间轴绑定事件列表

文章描述了如何使用Cesium库在时间轴上实现自定义事件,通过监听`onTick`事件并在特定时间触发JavaScript动作,如显示/隐藏元素。当时间轴播放完成时,事件处理逻辑会相应调整。

        //事件

        viewer.clock.onTick.addEventListener(onTick);

        viewer.clock.onStop.addEventListener(onStop);

        var isAction=false;

        // 定义要执行的事件和对应的时间

        var events = [

            { time: Cesium.JulianDate.fromDate(tlm.GetDateTime(2023, 11, 29, 8, 6, 0)), action: function () {  $(".labelcontent").show();console.log("事件1"); } },

            { time: Cesium.JulianDate.fromDate(tlm.GetDateTime(2023, 11, 29, 8, 7, 0)), action: function () {  $(".labelcontent").hide();console.log("事件2"); } },

            { time: Cesium.JulianDate.fromDate(tlm.GetDateTime(2023, 11, 29, 8, 8, 0)), action: function () {  $(".labelcontent").show();console.log("事件3"); } }

        ];

        var temp=[...events];

        //事件方法    

        function onTick(clock) {

            var currentTime = viewer.clock.currentTime;

            if (viewer.clock.shouldAnimate == true) {

                // console.log("时间:"+ currentTime);

                // 检查每个事件的时间

                for (var i = 0; i < temp.length; i++) {

                    var event = temp[i];

                    // 判断当前时间是否达到事件的时间

                    if (Cesium.JulianDate.greaterThanOrEquals(currentTime,event.time)) {

                        console.log("事件:"+ event.time);

                        // 执行事件

                        event.action();

                        // 可选择取消事件执行,以避免重复执行

                        temp.splice(i, 1); // 从事件列表中移除已执行的事件

                    }

                }

                // 如果所有事件都已执行完毕,可以选择停止监听onTick事件

                if (temp.length === 0) {

                    viewer.clock.onTick.removeEventListener(arguments.callee);//

                }

            }

        }

        //事件停止

        function onStop(clock) {

            console.log("时间轴播放完成时候");

            temp=[...events];

            viewer.clock.onTick.addEventListener(onTick)

        }

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值