基于Cesium实现拖拽3D模型的示例代码

 更新时间:2022年06月22日 15:49:00   作者:王+V  
这篇文章主要为大家详细介绍了如何利用Cesium实现在地图上添加一个3D模型,并且可以实现拖拽效果。文中的示例代码讲解详细,感兴趣的可以了解一下

这个地方是想实现一个什么效果呢?就是使用 cesium 在地图上添加一个3D模型,然后实现拖拽效果。

添加基站模型

然后这篇博文介绍的主要不是添加模型,但是也简单把代码直接粘贴过来吧,就不详细说了。

  // 添加基站模型
  function addSite() {
    let position = Cesium.Cartesian3.fromDegrees(116.236393, 40.075119, 0);
    // 设置模型方向
    let hpRoll = new Cesium.HeadingPitchRoll(Cesium.Math.toRadians(0), 0, 0);
    let orientation = Cesium.Transforms.headingPitchRollQuaternion(position, hpRoll);
    // 添加模型
    let model = viewer.entities.add({
      id: 'site',   // 模型id
      position: position,   // 模型位置
      orientation: orientation,   // 模型方向
      model: {
        uri: './models/siteModel/scene.gltf',   // 模型路径,自己换成自己的模型
        scale: 1,
        show: true, // 模型是否可见
      },
      description: '基站模型'  // 添加模型描述
    });
    viewer.trackedEntity = model;    // 视角切换到模型
  }

上边的代码就完成了在界面上添加模型功能。

拖拽

其实拖拽就是给这个cesium加一个监听事件。

比如说这个拖拽的简单逻辑分析哈:

1、鼠标按下事件,如果有模型的话,可以给模型设置一个颜色,知道按下选中的是哪个模型。

2、然后再监听鼠标拖拽事件,获取鼠标拖拽的位置,赋值给模型。

3、鼠标抬起事件,结束鼠标移动事件,然后把颜色改回去。

   // 注册事件
  function setHandler() {
    handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas);
    // 注册鼠标按下事件
    handler.setInputAction((e) => {
      const pick = viewer.scene.pick(e.position);
      if (!Cesium.defined(pick)) { return; };// 如果点击空白区域,则不往下执行
      viewer.scene.screenSpaceCameraController.enableRotate = false;// 将相机锁定,不然后续移动实体时相机也会动
      pick.id.model.color = Cesium.Color.fromAlpha(Cesium.Color.RED, 1)  //设置颜色

      // 注册鼠标拖拽事件
      viewer.screenSpaceEventHandler.setInputAction((arg) => {// 为viewer绑定MOUSE_MOVE事件监听器(执行函数,监听的事件)
        const position = arg.endPosition;// arg有startPosition与endPosition两个属性,即移动前后的位置信息:Cartesian2对象
        const cartesian = viewer.scene.globe.pick(viewer.camera.getPickRay(position), viewer.scene);//将Cartesian2转为Cartesian3
        pick.id.position._value = cartesian
      }, Cesium.ScreenSpaceEventType.MOUSE_MOVE);


      // 绑定鼠标抬起事件
      viewer.screenSpaceEventHandler.setInputAction(({ position }) => {//为viewer绑定LEFT_UP事件监听器(执行函数,监听的事件)
        viewer.scene.screenSpaceCameraController.enableRotate = true;// 取消相机锁定
        pick.id.model.color = null  //设置颜色
        viewer.screenSpaceEventHandler.removeInputAction(Cesium.ScreenSpaceEventType.MOUSE_MOVE);// 解除viewer的MOUSE_MOVE事件监听器
      }, Cesium.ScreenSpaceEventType.LEFT_UP)

    }, Cesium.ScreenSpaceEventType.LEFT_DOWN);
  }

完成了这就,就是这么的简单。

到此这篇关于基于Cesium实现拖拽3D模型的示例代码的文章就介绍到这了,更多相关Cesium拖拽3D模型内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • JavaScript中的undefined学习总结

    JavaScript中的undefined学习总结

    这篇文章主要是对JavaScript中的undefined进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2013-11-11
  • javascript自启动函数的问题探讨

    javascript自启动函数的问题探讨

    自启动函数想必大家并不陌生吧,在本文将为大家详细探讨下,感兴趣的朋友可不要错过
    2013-10-10
  • 整理Javascript函数学习笔记

    整理Javascript函数学习笔记

    整理Javascript函数学习笔记,之前一系列的文章是跟我学习Javascript,本文就是进一步学习Javascript函数,希望大家继续关注
    2015-12-12
  • js控制文本框只输入数字和小数点的方法

    js控制文本框只输入数字和小数点的方法

    这篇文章主要介绍了js控制文本框只输入数字和小数点的方法,实例分析了javascript使用正则表达式实现限制数字和小数点的技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-03-03
  • js图片轮播特效代码分享

    js图片轮播特效代码分享

    这篇文章主要介绍了js图片轮播特效,图片切换效果特别适合做产品演示,感兴趣的小伙伴可以参考下
    2015-09-09
  • js实现多图和单图上传显示

    js实现多图和单图上传显示

    这篇文章主要为大家详细介绍了js实现多图和单图上传显示,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-12-12
  • es6中class类静态方法,静态属性,实例属性,实例方法的理解与应用分析

    es6中class类静态方法,静态属性,实例属性,实例方法的理解与应用分析

    这篇文章主要介绍了es6中class类静态方法,静态属性,实例属性,实例方法的理解与应用,结合实例形式分析了es6 class类静态方法,静态属性,实例属性,实例方法相关概念、原理、用法及相关操作注意事项,需要的朋友可以参考下
    2020-02-02
  • 全面解析JavaScript 中 null

    全面解析JavaScript 中 null

    null 是一种原始类型,表示有意不包含任何对象值,在这篇文章中,你将学习关于 JavaScript 中的 null 的一切: 它的含义,如何检测它,null 和 undefined 之间的区别,以及为什么大量使用 null 会造成代码维护困难等,需要的朋友可以参考下
    2022-09-09
  • javascript 中null和undefined区分和比较

    javascript 中null和undefined区分和比较

    这篇文章主要介绍了javascript 中null和undefined区分和比较的相关资料,需要的朋友可以参考下
    2017-04-04
  • JavaScript常用数学函数用法示例

    JavaScript常用数学函数用法示例

    这篇文章主要介绍了JavaScript常用数学函数用法,结合实例形式分析了JavaScript常见的对数、平方、绝对值、正弦、四舍五入等相关数学函数使用技巧,需要的朋友可以参考下
    2018-05-05

最新评论