国产久_亚欧精品一区_久久亚洲美女_99精品在线观看_日韩成人三级_久久精品久久久久

顯示源代碼
3D行政區域可視化
 開發文檔
            <!DOCTYPE html>

<html>
  <head>
    <meta charset="UTF-8" />
    <meta
      name="viewport"
      content="initial-scale=1,maximum-scale=1,user-scalable=no"
    />
    <link
      href="http://www.bt68f.cn:9000/bigemap-gl.js/v1.1.0/Widgets/widgets.css"
      rel="stylesheet"
    />
    <script src="http://www.bt68f.cn:9000/bigemap-gl.js/v1.1.0/bigemap-gl.js"></script>
    <style>
      body {
        margin: 0;
        padding: 0;
      }

      #container {
        position: absolute;
        top: 0;
        bottom: 0;
        width: 100%;
        background-image: url("/bmgl/3dksh/bj.jpg");
        background-repeat: no-repeat;
        background-size: 100%;
      }

      .bmgl-widget-credits {
        display: none;
      }
    </style>
    <title>part_test</title>
  </head>
  <body>
    <div id="container"></div>

    <script>
      bmgl.Config.HTTP_URL = 'http://ua.bigemap.com:30081/bmsdk/';
      var viewer = new bmgl.Viewer("container", {
        mapId: "bigemap.dc-tian-w-satellite",
        requestRenderMode: false,
        orderIndependentTranslucency: false,
        contextOptions: {
          webgl: {
            alpha: true,
          },
        },
      });
      viewer.BMWidget.screenSpaceEventHandler.removeInputAction(
        bmgl.ScreenSpaceEventType.LEFT_CLICK
      );

      var scene = viewer.scene;
      var handler = new bmgl.ScreenSpaceEventHandler(scene.canvas);
      var ellipsoid = scene.globe.ellipsoid; //得到當前三維場景的橢球體

      //關閉地圖元素
      viewer.scene.globe.show = false;
      viewer.scene.skyBox.show = false; //隱藏天空盒子
      viewer.scene.backgroundColor = new bmgl.Color(0.0, 0.0, 0.0, 0.0); //隱藏黑色背景
      viewer.scene.globe.baseColor = new bmgl.Color(0, 0, 0, 0); //替換球體默認藍色
      viewer.scene.globe.enableLighting = false; //隱藏太陽
      viewer.shadows = false;
      viewer.scene.sun.show = false; //或者viewer.scene.sun.destroy();
      viewer.scene.moon.show = false; //隱藏月亮
      viewer.scene.skyAtmosphere.show = false; //大氣圈
      viewer.scene.fog.enable = false; //霧

      viewer.imageryLayers.remove(viewer.imageryLayers.get(0), false);

      //加載省市
      var promise = bmgl.KmlDataSource.load("/bmgl/3dksh/sichuan.kml");
      promise
        .then(function (dataSource) {
          viewer.dataSources.add(dataSource);
          //Get the array of entities
          var entities = dataSource.entities.values;
          var colorHash = {};
          for (var i = 0; i < entities.length; i++) {
            //For each entity, create a random color based on the state name.
            //Some states have multiple entities, so we store the color in a
            //hash so that we use the same color for the entire state.
            var entity = entities[i];

            if (entity.polygon) {
              var name = entity.name;

              viewer.entities.add({
                polygon: {
                  hierarchy: entity.polygon.hierarchy.getValue(),
                  outline: true,
                  material: new bmgl.ImageMaterialProperty({
                    image: "/bmgl/3dksh/sc.png",
                    repeat: new bmgl.Cartesian2(1, 1),
                  }),
                  extrudedHeight: 20000,
                },
              });
            }
          }
          viewer.flyTo(viewer.entities);
        })
        .otherwise(function (error) {
          //Display any errrors encountered while loading.
          window.alert(error);
        });

      var promise = bmgl.KmlDataSource.load("/bmgl/3dksh/soncity.kml");
      promise
        .then(function (dataSource) {
          viewer.dataSources.add(dataSource);
          //Get the array of entities
          var entities = dataSource.entities.values;
          var colorHash = {};
          for (var i = 0; i < entities.length; i++) {
            //For each entity, create a random color based on the state name.
            //Some states have multiple entities, so we store the color in a
            //hash so that we use the same color for the entire state.
            var entity = entities[i];

            if (entity.polygon) {
              var name = entity.name;

              //畫多邊形
              viewer.entities.add({
                name: name,
                type: "polygon",
                polygon: {
                  hierarchy: entity.polygon.hierarchy.getValue(),
                  outline: true,
                  material: new bmgl.Color(0, 0, 0, 0.1),
                  extrudedHeight: 21000,
                },
              });

              //畫邊界線
              let xyzs = entity.polygon.hierarchy.getValue();

              //添加標注
              drawLabel(xyzs.positions, name);

              //畫線
              let latlngs = [];
              xyzs.positions.forEach((v) => {
                let tmplatlng = xyz2latlng(v);
                tmplatlng.forEach((l) => {
                  latlngs.push(l);
                });
              });
              drawLine(latlngs);
            }
          }
          viewer.flyTo(viewer.entities);
        })
        .otherwise(function (error) {
          //Display any errrors encountered while loading.
          window.alert(error);
        });

      //記錄上一個點擊的entity
      let lastentity = "";

      handler.setInputAction(function (e) {
        var entity = viewer.scene.pick(e.position);

        console.log(entity);
        console.log(lastentity);
        if (entity != undefined) {
          if (entity.id.type == "polygon") {
            if (lastentity != "") {
              lastentity.material = new bmgl.Color(0, 0, 0, 0.1);
            }
            lastentity = entity.id.polygon;
            lastentity.material = new bmgl.Color(0.4, 0, 0, 0.8);
            console.log(entity.id.name);
          }
        } else {
          if (lastentity != "") {
            lastentity.material = new bmgl.Color(0, 0, 0, 0.1);
          }
          lastentity = "";
        }
      }, bmgl.ScreenSpaceEventType.LEFT_CLICK);

      function xyz2latlng(xyz, height = 20100) {
        let wgs84 = ellipsoid.cartesianToCartographic(xyz);
        let lng = bmgl.Math.toDegrees(wgs84.longitude);
        let lat = bmgl.Math.toDegrees(wgs84.latitude);
        return [lng, lat, height];
      }

      function drawLine(latlngs) {
        var orangeOutlined = viewer.entities.add({
          type: "line",
          polyline: {
            positions: bmgl.Cartesian3.fromDegreesArrayHeights(latlngs),
            width: 5,
            material: new bmgl.PolylineOutlineMaterialProperty({
              color: bmgl.Color.ORANGE,
              outlineWidth: 2,
              outlineColor: bmgl.Color.BLACK,
            }),
          },
        });
      }

      function drawLabel(polyPositions, name) {
        let polyCenter = bmgl.BoundingSphere.fromPoints(polyPositions).center;
        polyCenter = bmgl.Ellipsoid.WGS84.scaleToGeodeticSurface(polyCenter);

        let xyz = new bmgl.Cartesian3(polyCenter.x, polyCenter.y, polyCenter.z);
        let wgs84 = ellipsoid.cartesianToCartographic(xyz);
        let lng = bmgl.Math.toDegrees(wgs84.longitude);
        let lat = bmgl.Math.toDegrees(wgs84.latitude);
        viewer.entities.add({
          type: "label",
          position: bmgl.Cartesian3.fromDegrees(lng, lat, 40000),
          label: {
            scale: 0.6,
            showBackground: true,
            backgroundColor: new bmgl.Color(0.165, 0.165, 0.165, 0.5),
            fillColor: bmgl.Color.WHITE,
            text: name,
            disableDepthTestDistance: 900000,
          },
        });
      }
    </script>
  </body>
</html>
        
国产久_亚欧精品一区_久久亚洲美女_99精品在线观看_日韩成人三级_久久精品久久久久
<code id="kseui"><acronym id="kseui"></acronym></code>
  • <abbr id="kseui"><tbody id="kseui"></tbody></abbr>
  • <button id="kseui"></button>
  • 亚洲在线欧美| 中文网丁香综合网| 在线免费高清一区二区三区| 国产精品久久久久久久久久久久午夜片 | 99热在线播放| 亚洲激情二区| 欧美不卡三区| 亚洲国产午夜伦理片大全在线观看网站| 午夜亚洲影视| 一区二区久久| 91久久夜色精品国产九色| 亚洲精品国产精品国自产观看| 国产精品日韩一区二区三区 | 在线观看精品视频| 欧美乱偷一区二区三区在线| 国产高清一区二区三区| 91福利视频导航| 久久久久久婷| 美女91精品| 美女精品在线观看| 亚洲欧美日韩精品一区二区| 夜夜爽99久久国产综合精品女不卡| 中文字幕日韩精品久久| 午夜精品视频在线观看一区二区| 欧美凹凸一区二区三区视频| 精品免费视频123区| 久久riav| 免费看污久久久| 欧美日韩一区在线播放| 青青草成人网| 日本一区二区在线视频| 色爱区成人综合网| 亚洲高清精品中出| 欧美在线精品一区| 在线精品亚洲一区二区| aa日韩免费精品视频一| 一区二区三区导航| 久久五月天婷婷| 国产精品一区二区三区精品| 日韩欧美一区二区三区久久婷婷| 日韩精品一区二区三区丰满| 亚洲丰满在线| 在线播放不卡| 久久精品中文| 久久精品中文字幕一区二区三区 | yellow视频在线观看一区二区| 古典武侠综合av第一页| 欧美精品一区二区视频| 亚洲图片小说在线| 亚洲激情黄色| 老司机精品视频网站| 久久精品国产精品国产精品污 | 老司机精品久久| 看高清中日韩色视频| 亚洲一区二区精品在线观看| 亚洲一级高清| y111111国产精品久久婷婷| 欧洲国产精品| 狠狠综合久久av一区二区老牛| 国产精品日韩精品欧美精品| 国产精品一区在线观看| 亚洲乱码一区二区三区| 欧美午夜一区| 亚洲国产精品一区二区第四页av| 国产九区一区在线| 欧美理论一区二区| 好看的日韩av电影| 久久久亚洲人| 在线观看精品视频| 99在线看视频| 欧美日韩在线精品| 国产一区二区高清不卡| 欧美午夜不卡| 国产精品一区而去| 午夜天堂精品久久久久| 国产精华一区二区三区| 欧美不卡三区| 免费精品视频一区| 男人的天堂亚洲| 中文字幕免费在线不卡| 超碰97人人人人人蜜桃| 国内精品久久久久久久97牛牛 | 一区二区三区偷拍| 久久aⅴ乱码一区二区三区| 日韩久久久久久久| 久久一区二区三区四区五区| 午夜精品偷拍| 欧美精品一区二区三区久久| 噜噜噜躁狠狠躁狠狠精品视频| 亚洲精品一卡二卡三卡四卡| 久久婷婷麻豆| 亚洲看片免费| 欧美在线首页| 欧美精品亚洲| 国产高清自拍99| 亚洲三级网站| 欧美激情无毛| 亚洲bbw性色大片| 国产精品一国产精品最新章节| 夜夜嗨av一区二区三区网站四季av| 亚洲7777| 色乱码一区二区三在线看| 国产成人一区二区三区免费看| 国产精品久久久久久久久久妞妞 | 欧美不卡三区| 亚洲蜜桃在线| 日本一区二区高清视频| 国产一区自拍视频| 91gao视频| 久久综合精品一区| 在线亚洲美日韩| 亚洲国产专区校园欧美| 国产精品va| 欧美日韩免费观看一区| 综合网五月天| 中文字幕在线中文字幕日亚韩一区| 日本视频精品一区| 欧美日本韩国一区二区三区| 精品视频一区在线| 国产精品区免费视频| 97中文在线| 国产精品久久久久久久免费大片 | 亚洲精品国产精品国自产观看| 欧洲在线视频一区| 日韩理论片在线观看| 影音先锋一区| 狠狠入ady亚洲精品| 国产精品av久久久久久麻豆网| 欧美高清视频一区二区三区在线观看| 日韩中文一区| 欧美福利在线| 在线亚洲观看| 久久综合导航| 韩国成人一区| 亚洲v国产v| 亚洲高清在线观看一区| 国产日韩1区| 97久草视频| 久久综合福利| 欧美一区国产一区| 亚洲黄色视屏| 97人人澡人人爽| 欧美极品视频一区二区三区| 色中色综合成人| 国产在线日韩| 久久精品在线| 秋霞在线观看一区二区三区| 亚洲最大免费| 国产一区二区久久久| 国产精品久久久久久久小唯西川| 久久免费一区| 国产精品v欧美精品v日韩 | 亚洲国产精品久久久久久女王| 欧美黄在线观看| 亚洲欧美日产图| 蜜桃传媒一区二区| 国产精品地址| 99免费在线观看视频| 亚洲国产精品一区在线观看不卡| 欧美日韩第一区| 97人人香蕉| 午夜日韩激情| 国产伦精品一区二区| 欧洲久久久久久| 亚洲精品1区| 久久亚洲精品欧美| 91久久精品国产91久久性色tv| 国产尤物91| 亚洲一级高清| 免费观看成人在线| 国产日本精品| 日韩一区国产在线观看| 亚洲一区二区三区精品动漫| 欧美日韩在线观看一区| 日韩亚洲国产欧美| 日本不卡一区| 久久一本综合频道| 韩国av一区| 欧美 日韩 国产在线| 99视频+国产日韩欧美| 欧美在线激情| 久久久久久亚洲精品不卡4k岛国| 杨幂一区欧美专区| 国产欧美一区二区在线播放| 国内精品久久久久久久影视蜜臀| 国产伦精品一区二区三区免费视频 | 国产日本精品| 女人色偷偷aa久久天堂| 国产乱码精品一区二区三区日韩精品| 精品不卡一区二区三区| 精品麻豆av| 老司机精品导航| 亚洲精品激情| 午夜精品一区二区三区四区| 蜜桃久久精品乱码一区二区 | 欧美三日本三级少妇三99| 国产欧美日本在线| 亚洲欧美影院| 视频在线99| 久久久久久99|