cesium 缩放速度控制

cesium  缩放速度控制

需求:

cesium 缩放速度控制,  在移动端浏览器访问时,两个手指缩放地球速度有点慢,希望可以修改。

实现:

修改 zoomEventTypes,禁用cesium默认触控缩放

gvEarth.scene.screenSpaceCameraController.zoomEventTypes 默认值为

[ CameraEventType.RIGHT_DRAG , CameraEventType.WHEEL , CameraEventType.PINCH ]

修改为:

gvEarth.scene.screenSpaceCameraController.zoomEventTypes = [

        Cesium.CameraEventType.MIDDLE_DRAG,

        Cesium.CameraEventType.WHEEL,

];

js监控手指缩放动作,参考文章:移动端双指缩放图片JS事件的实践心得 - 浅笑· - 博客园

var store = {};

 document.addEventListener('touchstart', function (event) {

    var touches = event.touches;

    var events = touches[0];

    var events2 = touches[1];

    event.preventDefault();

    // 第一个触摸点的坐标

    store.pageX = events.pageX;

    store.pageY = events.pageY;

    store.moveable = true;

    if (events2) {

        store.pageX2 = events2.pageX;

        store.pageY2 = events2.pageY;

    }

});

document.addEventListener('touchmove', function (event) {

    if (!store.moveable) {

        return;

    }

    event.preventDefault();

    var touches = event.touches;

    var events = touches[0];

    var events2 = touches[1];

    // 双指移动

    if (events2) {

        // 第2个指头坐标在touchmove时候获取

        if (!store.pageX2) {

            store.pageX2 = events2.pageX;

        }

        if (!store.pageY2) {

            store.pageY2 = events2.pageY;

        }

        

        // 获取坐标之间的距离

        var getDistance = function (start, stop) {

            return Math.hypot(stop.x - start.x, stop.y - start.y);

        };

        // 双指缩放比例计算

        var zoom = getDistance({

            x: events.pageX,

            y: events.pageY

        }, {

            x: events2.pageX,

            y: events2.pageY

        }) /

        getDistance({

            x: store.pageX,

            y: store.pageY

        }, {

            x: store.pageX2,

            y: store.pageY2

        });

        if (zoom > 1) {

            zoomIn();

        }else{

          zoomOut()

        }

       store.pageX = events.pageX;

       store.pageY = events.pageY;

       store.pageX2 = events2.pageX;

       store.pageY2 = events2.pageY;

    }

});

document.addEventListener('touchend', function () {

    store.moveable = false;

    delete store.pageX2;

    delete store.pageY2;

});

document.addEventListener('touchcancel', function () {

    store.moveable = false;

    delete store.pageX2;

    delete store.pageY2;

});

let firstTime2 = performance.now();

function zoomIn(){

  const secondTime2 = performance.now();

        if (secondTime2 - firstTime2 < 200) {

          const height = gvEarth.camera.positionCartographic.height;

          gvEarth.camera.zoomIn(height / 15);

          firstTime2 = 0;

        }

        firstTime2 = secondTime2;

}

let firstTime3 = performance.now();

function zoomOut(){

  const secondTime3 = performance.now();

        if (secondTime3 - firstTime3 < 200) {

          const height = gvEarth.camera.positionCartographic.height;

          gvEarth.camera.zoomOut(height / 15);

          firstTime3 = 0;

        }

        firstTime3 = secondTime3;

}

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值