CZML格式漫游

 CZML

  // 去程漫游数组含时间
  const mudroutemove1 = [
    0.00, 121.789100, 29.523650, 1,
    3.04, 121.784900, 29.538920, 1,
    9.65, 121.762580, 29.540210, 1,
    14.84, 121.745300, 29.537620, 1,
    19.23, 121.735380, 29.548420, 1,
    24.15, 121.736150, 29.562033, 1,
    30.49, 121.748200, 29.568783, 1,
    43.67, 121.791083, 29.614317, 1,
    60.61, 121.907983, 29.669800, 1,
    72.84, 121.962350, 29.669800, 1,
    88.94, 122.026617, 29.669800, 1,
    94.40, 122.032300, 29.706083, 1,
    99.35, 122.036650, 29.718400, 1,
    107.94, 122.046683, 29.733233, 1,
    118.33, 122.061150, 29.763567, 1,
    122.86, 122.064117, 29.774383, 1,
    130.03, 122.073817, 29.785017, 1,
    147.90, 122.122400, 29.805900, 1,
    160.74, 122.149600, 29.817517, 1,
    182.19, 122.196983, 29.840850, 1,
    195.78, 122.222217, 29.853200, 1,
    213.71, 122.240233, 29.876617, 1,
    228.10, 122.256983, 29.889633, 1,
  ];
  // 返程漫游数组含时间
  const mudroutemove2 = [
    0, 122.301033, 29.906350, 1,
    15, 122.228633, 29.878350, 1,
    18, 122.225283, 29.874033, 1,
    26, 122.202533, 29.862500, 1,
    46, 122.067283, 29.793933, 1,
    52, 122.064117, 29.774383, 1,
    58, 122.061150, 29.763567, 1,
    72, 122.046683, 29.733233, 1,
    80, 122.036650, 29.718400, 1,
    86, 122.032300, 29.706083, 1,
    104, 122.016450, 29.671333, 1,
    120, 121.962667, 29.671333, 1,
    136, 121.908333, 29.671333, 1,
    150, 121.790167, 29.615333, 1,
    160, 121.747333, 29.569667, 1,
    165, 121.736150, 29.562033, 1,
    170, 121.735380, 29.548420, 1,
    175, 121.745300, 29.537620, 1,
    180, 121.762580, 29.540210, 1,
    185, 121.784900, 29.538920, 1,
    190, 121.789100, 29.523650, 1,
    195, 122.301033, 29.906350, 1,
    200, 122.228633, 29.878350, 1,
  ];
 // 去程航线漫游
  const mudmove1czml: any = [
    {
      id: 'document',
      name: 'CZML Path',
      version: '1.0',
      clock: {
        interval: '2012-08-04T10:00:00Z/2012-08-04T15:00:00Z',
        currentTime: '2012-08-04T10:00:00Z',
        multiplier: 0.6,
      },
    },
    {
      id: 'gopath',
      name: 'path with GPS flight data',
      availability: '2012-08-04T10:00:00Z/2012-08-04T15:00:00Z',
      path: {
        material: {
          polylineOutline: {
            color: {
              rgba: [255, 0, 255, 255],
            },
            outlineColor: {
              rgba: [0, 255, 255, 255],
            },
            outlineWidth: 5,
          },
        },
        width: 8,
        leadTime: 5,
        trailTime: 5,
        resolution: 5,
      },
      billboard: {
        image:
        '',
        scale: 1,
        eyeOffset: {
          cartesian: [0.0, 0.0, -10.0],
        },
      },
      position: {
        epoch: '2012-08-04T10:00:00Z',
        cartographicDegrees: mudroutemove1,
      },
    },
  ];
  // 返程航线漫游
  const mudmove2czml: any = [
    {
      id: 'document',
      name: 'CZML Path',
      version: '1.0',
      clock: {
        interval: '2012-08-04T10:00:00Z/2012-08-04T15:00:00Z',
        currentTime: '2012-08-04T10:00:00Z',
        multiplier: 0.6,
      },
    },
    {
      id: 'returnpath',
      name: 'path with GPS flight data',
      availability: '2012-08-04T10:00:00Z/2012-08-04T15:00:00Z',
      path: {
        material: {
          polylineOutline: {
            color: {
              rgba: [255, 0, 255, 255],
            },
            outlineColor: {
              rgba: [0, 255, 255, 255],
            },
            outlineWidth: 5,
          },
        },
        width: 8,
        leadTime: 5,
        trailTime: 5,
        resolution: 5,
      },
      billboard: {
        image:
        '',
        scale: 1,
        eyeOffset: {
          cartesian: [0.0, 0.0, -10.0],
        },
      },
      position: {
        epoch: '2012-08-04T10:00:00Z',
        cartographicDegrees: mudroutemove2,
      },
    },
  ];

 (1)vuecesium

      <vc-datasource-czml
        ref="datasourceRef"
        v-if="shipRouteInfo[0].show"
        :czml="mudmove1czml"
        @ready="onDatasourceReady"
        :show="wandershow"
      />

// 航线漫游
const wandershow = ref(true);
const datasourceRef: any = ref(null);
const wander = async () => {
  reload();
};

const unload = () => {
  // datasourceRef.value.unload();
  viewer.trackedEntity = null;
  viewer.camera.flyTo({
    destination: Cesium.Cartesian3.fromDegrees(122.05, 29.82, 80000),
    orientation: {
      heading: Cesium.Math.toRadians(0),
      pitch: Cesium.Math.toRadians(-90),
      // rolling: 0.4,
    },
  });
};
const reload = () => {
  datasourceRef.value.reload();
};
const load = () => {
  datasourceRef.value.load();
};
const onDatasourceReady = () => {
  unload();
};

(2)czml

const wander = async (type:string, _viewer: any, _cesium: any) => {
  let dataSource:any = null;
  let entity:any = null;
  if (type === 'go') {
    dataSource = await viewer.dataSources.add(
      _cesium.CzmlDataSource.load(mudmove1czml),
    );
    entity = dataSource.entities.getById('gopath');
  } else if (type === 'return') {
    dataSource = await viewer.dataSources.add(
      _cesium.CzmlDataSource.load(mudmove2czml),
    );
    entity = dataSource.entities.getById('returnpath');
  }
  _viewer.trackedEntity = entity;
};

 (3)ion asset gltf model

 // 去程点[]
  const mudroute1 = [
    121.789100, 29.523650, 1, // 西沪港转运点
    121.784900, 29.538920, 1, //
    121.762580, 29.540210, 1, //
    121.745300, 29.537620, 1, //
    121.735380, 29.548420, 1, //
    121.736150, 29.562033, 1, // 进入NBZ-10航路
    121.748200, 29.568783, 1, //
    121.791083, 29.614317, 1, // 穿越象山港公路大桥
    121.907983, 29.669800, 1, //
    121.962350, 29.669800, 1, // 宁电(1)灯浮
    122.026617, 29.669800, 1, //
    122.032300, 29.706083, 1, // 进入双屿门临时航道
    122.036650, 29.718400, 1, // 开始沿西航路航行
    122.046683, 29.733233, 1, //
    122.061150, 29.763567, 1, //
    122.064117, 29.774383, 1, // 6#警戒区南侧转向点
    122.073817, 29.785017, 1, //
    122.122400, 29.805900, 1, // 开始穿越7#警戒区
    122.149600, 29.817517, 1, //
    122.196983, 29.840850, 1, // 开始穿越1#警戒区
    122.222217, 29.853200, 1, // 岙山联检锚地南侧转向点
    122.240233, 29.876617, 1, // 蚂蚁岛与点灯山水域
    122.256983, 29.889633, 1, //
    122.301033, 29.906350, 1, // 水老鼠礁临时海洋倾倒区
  ];
  // 去程点数组[[]]
  const mudrouteforgo = [
    [121.789100, 29.523650, 1], // 西沪港转运点
    [121.784900, 29.538920, 1],
    [121.762580, 29.540210, 1],
    [121.745300, 29.537620, 1],
    [121.735380, 29.548420, 1],
    [121.736150, 29.562033, 1], // 进入NBZ-10航路
    [121.748200, 29.568783, 1],
    [121.791083, 29.614317, 1], // 穿越象山港公路大桥
    [121.907983, 29.669800, 1],
    [121.962350, 29.669800, 1], // 宁电(1)灯浮
    [122.026617, 29.669800, 1],
    [122.032300, 29.706083, 1], // 进入双屿门临时航道
    [122.036650, 29.718400, 1], // 开始沿西航路航行
    [122.046683, 29.733233, 1],
    [122.061150, 29.763567, 1],
    [122.064117, 29.774383, 1], // 6#警戒区南侧转向点
    [122.073817, 29.785017, 1],
    [122.122400, 29.805900, 1], // 开始穿越7#警戒区
    [122.149600, 29.817517, 1],
    [122.196983, 29.840850, 1], // 开始穿越1#警戒区
    [122.222217, 29.853200, 1], // 岙山联检锚地南侧转向点
    [122.240233, 29.876617, 1], // 蚂蚁岛与点灯山水域
    [122.256983, 29.889633, 1],
    [122.301033, 29.906350, 1], // 水老鼠礁临时海洋倾倒区
  ];
async function loadModel(_viewer: any, _cesium: any, start: any, stop: any, positionProperty:any) {
  const airplaneUri = await _cesium.IonResource.fromAssetId(1689756);
  const airplaneEntity = _viewer.entities.add({
    availability: new Cesium.TimeIntervalCollection([new Cesium.TimeInterval({ start, stop })]),
    position: positionProperty,
    model: { uri: airplaneUri },
    orientation: new Cesium.VelocityOrientationProperty(positionProperty),
    // path: new Cesium.PathGraphics({ width: 3 }),
  });
  viewer.trackedEntity = airplaneEntity;
}
const wander = async (type: string, _viewer: any, _cesium: any) => {
  const timeStepInSeconds = 60;
  let mudRoute:any;

  if (type === 'go') {
    mudRoute = mudrouteforgo;
  } else if (type === 'return') {
    mudRoute = mudrouteforreturn;
  } else {
    throw new Error('Invalid type provided');
  }

  const start = _cesium.JulianDate.fromIso8601('2020-03-09T23:10:00Z');
  const totalSeconds = timeStepInSeconds * (mudRoute.length - 1);
  const stop = _cesium.JulianDate.addSeconds(start, totalSeconds, new _cesium.JulianDate());

  _viewer.clock.startTime = start.clone();
  _viewer.clock.stopTime = stop.clone();
  _viewer.clock.currentTime = start.clone();
  _viewer.zoomTo(start, stop);
  _viewer.clock.multiplier = 10;
  _viewer.clock.shouldAnimate = true;

  const positionProperty = new _cesium.SampledPositionProperty();

  for (let i = 0; i < mudRoute.length; i++) {
    const dataPoint = mudRoute[i];
    const time = _cesium.JulianDate.addSeconds(start, i * timeStepInSeconds, new _cesium.JulianDate());
    const position = _cesium.Cartesian3.fromDegrees(dataPoint[0], dataPoint[1], dataPoint[2]);
    positionProperty.addSample(time, position);
  }
  loadModel(_viewer, _cesium, start, stop, positionProperty);
};

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值