mars3d的V2版本的Video2D与V3版本的Video2D实现数据快速迁移

场景:

目前是v2和v3的两个相机视角的不同格式,在Mars3d的V2的旧数据想可以快速迁移到V3版本。

V2版本的数据:

{
        "camera": {
                "fov": 1.0471975511965976,
                "dis": 20,
                "stRotation": 0,
                "showFrustum": true,
                "aspectRatio": 1.6022099447513811,
                "camera": {
                        "position": {
                                "x": -2177820.3029543245,
                                "y": 4388724.089003264,
                                "z": 4070105.7812721003
                        },
                        "direction": {
                                "x": 0.64574289308262001,
                                "y": 0.56956514491665855,
                                "z": -0.50853875145297822
                        },
                        "up": {
                                "x": -0.24582927592774592,
                                "y": 0.78563308172943203,
                                "z": 0.56775754331330175
                        },
                        "right": {
                                "x": 0.72289977391760774,
                                "y": -0.2416116855377268,
                                "z": 0.64733276626592173
                        }
                }
        }
}

迁移示例地址:V3的示例:
http://mars3d.cn/editor-vue.html?key=ex_7_10_4&id=graphic/video/video2D

迁移代码参考:

function addDemoGraphic1() {
  const video2D = new mars3d.graphic.Video2D({
    position: [117.205459, 31.842988, 64.3],
    style: oldStyle2New({
      camera: {
       "position": {"x": -2177820.3029543245,  "y": 4388724.089003264, "z": 4070105.7812721003},
        direction: { x: -0.20300781957546601, y: 0.3881445982693198, z: -0.8989613985180693 },
        up: { x: -0.41112481743883666, y: 0.7994469141644973, z: 0.43801942413407347 },
        right: { x: 0.8886867894129509, y: 0.4585067090754624, z: -0.0027180978075245542 }
      },
      dis: 70,
      fov: 52,
      aspectRatio: 3,
      stRotationDegree: 0
    })
  })
  graphicLayer.addGraphic(video2D) 
}

// 历史参数转为当前最新版本的参数
function oldStyle2New(oldStyle) {
  const camera = new Cesium.Camera(map.scene)
  camera.position = oldStyle.camera.position
  camera.direction = oldStyle.camera.direction
  camera.up = oldStyle.camera.up
  camera.right = oldStyle.camera.right

  const angle = Cesium.Math.toDegrees(oldStyle.fov/ 2)

  return {
    distance: oldStyle.dis,

    angle: angle,
    angle2: angle / oldStyle.aspectRatio,

    heading: Cesium.Math.toDegrees(camera.heading) - 90,
    pitch: Cesium.Math.toRadians(camera.pitch),
    roll: Cesium.Math.toRadians(camera.roll)
  }
}
相关推荐
Cachel wood22 分钟前
python round四舍五入和decimal库精确四舍五入
java·linux·前端·数据库·vue.js·python·前端框架
学代码的小前端24 分钟前
0基础学前端-----CSS DAY9
前端·css
joan_8528 分钟前
layui表格templet图片渲染--模板字符串和字符串拼接
前端·javascript·layui
m0_748236111 小时前
Calcite Web 项目常见问题解决方案
开发语言·前端·rust
Watermelo6171 小时前
详解js柯里化原理及用法,探究柯里化在Redux Selector 的场景模拟、构建复杂的数据流管道、优化深度嵌套函数中的精妙应用
开发语言·前端·javascript·算法·数据挖掘·数据分析·ecmascript
m0_748248941 小时前
HTML5系列(11)-- Web 无障碍开发指南
前端·html·html5
m0_748235611 小时前
从零开始学前端之HTML(三)
前端·html
冬天vs不冷2 小时前
Linux用户与权限管理详解
linux·运维·chrome
一个处女座的程序猿O(∩_∩)O3 小时前
小型 Vue 项目,该不该用 Pinia 、Vuex呢?
前端·javascript·vue.js
hackeroink6 小时前
【2024版】最新推荐好用的XSS漏洞扫描利用工具_xss扫描工具
前端·xss