船艦點位展示Widget使用教學


本章將說明船艦點位展示Widget的使用方式。

[info] 小提示:

SandBox連結:https://codesandbox.io/s/widget-ship-sample-l7v39h?file=/Script/main.js


[info] 小提示:

構成本Widget使用之Function:
ov.TerrainView.addCustomLayer
ov.TerrainView.removeAllEntity
ov.CustomLayer.addGLTFEntity
ov.CustomLayer.addPushpinEntity


初始化Widget

先撰寫一個最基本的圖台。

index.html

<!DOCTYPE html>
<html lang="en" xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <meta charset="utf-8" />
        <title>BaseMapWidget</title>
        <script src="PGWeb3D.min.js"></script>
    </head>
    <body>
        <div id="MyMap" style="width:100%;height:100%;position:absolute;top:0;left:0"></div>
        <script src="main.js"></script>
    </body>
</html>

將Widget初始化加進我們撰寫好的main.js中。

main.js

var terrainview = new window.ov.TerrainView("MyMap");
var LyrAPI1 = null;

//在使用其他圖層前必須要先讀入地形 其他圖層的新增都會在callback中
terrainview.openTerrain(
  {
     url: 'https://data-3dgdp.colife.org.tw/Sample_src/PGWebJS/13.0/oviewRP.ashx', // 或您自己的O'View MapServer服務
     identifier: "範例地形圖",
     callback: openCallback,
  }
);

function openCallback(result) {
  terrainview.setBaseLayer({
    url: "BING_MAP",
    identifier: "IMAGE"
  });

  //設定初始位置
  let initialPos = new window.GeoPoint(
    121.2347878442796,
    23.727553934089445,
    465850.0013822634
  );
  let initialV = new window.Geo3DPoint(0, 0, -1);
  let initialUp = new window.Geo3DPoint(0, 1, 0);
  let initialCamera = new window.ov.Camera(initialPos, initialV, initialUp);
  terrainview.gotoCamera(initialCamera, false);

  LyrAPI1 = terrainview.addCustomLayer({
    layername: "LyrAPI1"
  });
  //預設開啟船艦點位展示Widget
  ShipPtWidget();
}

function ShipPtWidget() {
  var ShipList = [
    {
      Name: "帆船",
      ModelAngle: 225,
      src: "ShipModel/boat_48.glb",
      COG: 20,
      Scale: 1,
      zScale: 0.8,
      Pos: new window.Geo3DPoint(119.5721, 23.56496, 0)
    },
    {
      Name: "漁船",
      ModelAngle: 180,
      src: "ShipModel/fishing_boat.glb",
      COG: 134,
      Scale: 0.025,
      zScale: 1,
      Pos: new window.Geo3DPoint(119.57352, 23.56559, 0)
    },
    {
      Name: "客輪",
      ModelAngle: 70,
      src: "ShipModel/ferry_concept.glb",
      COG: 51,
      Scale: 0.025,
      zScale: 1,
      Pos: new window.Geo3DPoint(119.57178, 23.56389, 0)
    }
  ];

  for (i = 0; i < ShipList.length; i++) {
    var Name = ShipList[i].Name;
    var ModelSrc = ShipList[i].src;
    var Pos = ShipList[i].Pos;
    var Scale = ShipList[i].Scale;
    var COG = ShipList[i].COG;
    var ModelAngle = ShipList[i].ModelAngle;
    var zScale = ShipList[i].zScale;
    LyrAPI1.addGLTFEntity({
      src: ModelSrc,
      position: Pos,
      scale: Scale,
      zScale: zScale,
      rotate: { x: 0, y: 1, z: 0, w: ModelAngle + COG }
    });

    LyrAPI1.addPushpinEntity({
      geo: Pos,
      size: 20,
      absHeight: false,
      pullUpY: 16,
      pullUpYIsWorldSize: true,
      text: Name
    });
  }

  //馬公漁港
  const pos = new window.Geo3DPoint(119.571, 23.55965, 150);
  const up = new Geo3DPoint({
    x: 0.12351633533189085,
    y: 0.3953696908560778,
    z: 0.9473652142184981
  });
  const v = new Geo3DPoint({
    x: 0.3654944598674774,
    y: 0.8740219473838806,
    z: -0.32015544176101685
  });
  const camera = new window.ov.Camera(pos, v, up);
  terrainview.gotoCamera(camera, false);
}

到目前為止,我們已成功將船艦點位展示Widget加入圖台中。

Copyright © NCHC 2022 Version:13.0 all right reserved,powered by Gitbook修訂時間: 2024-12-17 09:36:09