【Mars3D项目实战开发】加载水系河流,加载植被,加载区划街道社区吊牌,点击加载对应社区倾斜摄影

Mars3D有很多很强大的功能,可以在地球上实现很多炫酷的3D效果。今天继续给大家分享功能,在地球上加载水系河流,加载geojson植被,加载区划街道社区吊牌,点击社区可加载对应社区的倾斜摄影。

1.话不多说,先展示

水系,植被,区划吊牌,社区倾斜摄影

2.设计思路

通过axios获取要加载水系的点位数据,加载本地geojson的植被数据,获取请求的区划数据,点击可视角移动,社区的话可加载对应社区的倾斜摄影。

3.具体代码

bash 复制代码
<script setup>
import * as Cesium from "mars3d-cesium";
import * as mars3d from "mars3d";
//引入cesium基础库
import "mars3d-cesium/Build/Cesium/Widgets/widgets.css";
//导入mars3d主库
import "mars3d/mars3d.css"; //v3.8.6及之前版本使用 import "mars3d/dist/mars3d.css";
import axios from "axios";

//导入mars3d插件(按需使用,需要先npm install)
import "mars3d-space";
import { ref, onMounted, reactive } from "vue";

var tileLayer = reactive({});//天地图影像图层
var tiles3dLayer1 = reactive({});//白膜图层
var tiles3dLayer2 = reactive({});//倾斜摄影图层
var graphicLayer = reactive({});//区域边界,街道边界,水系,tyLoad, 区划
var graphicLayer2 = reactive({});//植被图层
var map = reactive({});

var grid = reactive({});
var list = ref([]);
var sxlist = ref([]);
var roadlist = ref([]);
var qhlist = ref([]);


var mapOptions = {
  terrain: {
    //地形
    url: "http://data.mars3d.cn/terrain",
    show: true,
  },
  scene: {
    // center: { lat: 30.422407, lng: 115.820222, alt: 3498, heading: 67, pitch: -32 },
    showSun: false, //是否显示太阳
    showMoon: false, //是否显示月亮
    showSkyBox: true, //是否显示天空盒
    showSkyAtmosphere: false, //是否显示地球大气层外光圈
    contextmenu: false,
    fog: false, //是否启用雾化效果
    globe: {
      showGroundAtmosphere: false,
      enableLighting: false,
      depthTestAgainstTerrain: true, // 地形检测,不加无法投射到地形上
    },
    fxaa: true, // 不开启抗锯齿,可视域会闪烁
    skyBox: {
      type: "ground",
      sources: {
        positiveX: "../assets/imgs/skybox/lantian/Right.jpg",
        negativeX: "../assets/imgs/skybox/lantian/Left.png",
        positiveY: "../assets/imgs/skybox/lantian/Front.png",
        negativeY: "../assets/imgs/skybox/lantian/Back.png",
        positiveZ: "../assets/imgs/skybox/lantian/Up.png",
        negativeZ: "../assets/imgs/skybox/lantian/Down.png",
      },
    },
  },

  basemaps: [
    {
      name: "天地图电子底图",
      layer: "vec_d",
      type: "tdt",
      invertColor: false, // 反向颜色 color.r = 1.0 - color.r
      filterColor: "#0950a9", // 滤镜颜色  color.r = color.r * filterColor.r
      brightness: 2, // 亮度
      contrast: 0.6, // 对比度
      hue: 0.1, // 色彩
      saturation: 1, // 饱和度
      gamma: 0.2, // 伽马值
      opacity: 1, // 透明度
      minimumLevel: 0,
      maximumLevel: 18,
      key: ["自己申请的天地图key"],
      show: true,
    },
  ],
};

onMounted(async() => {
  map = new mars3d.Map("mars3dContainer", mapOptions);
  graphicLayer = new mars3d.layer.GraphicLayer({
    hasEdit: false,
    isAutoEditing: false,
    clustering: {
      enabled: false,
      pixelRange: 20,
      clampToGround: false,
      addHeight: 1000,
    },
  });
  map.addLayer(graphicLayer);
  
  getBm();
  getGridBJ();
  getJdLists();
  getWater();
  wblzb();
  getRolad();
  getGrid("");

  setEvent();

});

//加载白膜数据 并动画到指定位置
const getBm = () => {
  tiles3dLayer1 = new mars3d.layer.TilesetLayer({
    name: "白膜",
    url: "http://172.16.10.83:9509/map3d/wbl/BM4/tileset.json",
    position: {
      alt: 0,
    },
    maximumScreenSpaceError: 256,
    zIndex: 3,
    show: true,
  });
  map.addLayer(tiles3dLayer1);

  //飞到指定经纬度
  map.openFlyAnimation({
    center: {
      lat: 37.84331,
      lng: 112.543554,
      alt: 1587.8,
      heading: 296,
      pitch: -17.2,
    },
  });
};

//加载wbl区域边界
const getGridBJ = async () => {
  await axios.get("http://172.16.10.83:8085/grid/getWkt").then((res) => {
    if (res.data.code == "20000000") {
      grid = res.data.data.grid;
        let item = grid;
        if (item.wkt.indexOf(")),MULTILINESTRING ((") == -1) {
              let wkt = item.wkt
                .split("MULTIPOLYGON (((")[1]
                .split(")))")[0]
                .split(", ");
              let positions = [];
              wkt.forEach((item1) => {
                let arr = [item1.split(" ")[0], item1.split(" ")[1]];
                positions.push(arr);
              });
              const graphic = new mars3d.graphic.PolylineEntity({
                id: item.id,
                name: item.name,
                positions: positions,
                style: {
                  width: 5,
                  color: "#867352",
                  clampToGround: true,
                },
                show: true,
              });
              graphicLayer.addGraphic(graphic);
              const graphic2 = new mars3d.graphic.PolylineEntity({
                positions: positions,
                style: {
                  width: 5,
                  clampToGround: true,
                  materialType: mars3d.MaterialType.LineFlicker,
                  materialOptions: {
                    color: "#867352",
                    speed: 10,
                  },
                },
                show: true,
              });
              graphicLayer.addGraphic(graphic2);
            }
    }
  });
};

//加载街道区域轮廓线
const getJdLists = async () => {
  await axios.get("http://172.16.10.83:8085/layer/jd").then((res) => {
    if (res.data.code == "20000000") {
      list.value = res.data.data.list;
      if (list.value.length > 0) {
        let listData = list.value;
        listData.forEach((item) => {
          if (item.wkt) {
            if (item.wkt.indexOf(")),MULTILINESTRING ((") == -1) {
              let wkt = item.wkt
                .split("MULTILINESTRING ((")[1]
                .split("))")[0]
                .split(", ");
              let positions = [];
              wkt.forEach((item1) => {
                let arr = [item1.split(" ")[0], item1.split(" ")[1]];
                positions.push(arr);
              });
              const graphic2 = new mars3d.graphic.PolylineEntity({
                positions: positions,
                style: {
                  width: 5,
                  color: "rgba(255,255,0,.02)",
                  clampToGround: true,
                },
                show: true,
              });
              graphicLayer.addGraphic(graphic2);
              const graphic = new mars3d.graphic.PolylineEntity({
                positions: positions,
                style: {
                  width: 5,
                  clampToGround: true,
                  materialType: mars3d.MaterialType.LineFlicker,
                  materialOptions: {
                    color: "#ffff00",
                    speed: 5,
                  },
                },
                zIndex: 5,
                show: true,
              });

              graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)
            } else {
              let pList = item.wkt.split(")),MULTILINESTRING ((");
              for (let i = 0; i < pList.length; i++) {
                let item2 = pList[i];
                if (item2.indexOf("MULTILINESTRING ((") != -1) {
                  let wkt = item2.split("MULTILINESTRING ((")[1].split(", ");
                  let positions = [];
                  wkt.forEach((item1) => {
                    let arr = [item1.split(" ")[0], item1.split(" ")[1]];
                    positions.push(arr);
                  });
                  const graphic2 = new mars3d.graphic.PolylineEntity({
                    positions: positions,
                    style: {
                      width: 5,
                      color: "rgba(255,255,0,.02)",
                      clampToGround: true,
                    },
                    show: true,
                  });
                  graphicLayer.addGraphic(graphic2);
                  const graphic = new mars3d.graphic.PolylineEntity({
                    positions: positions,
                    style: {
                      width: 3,
                      clampToGround: true,
                      materialType: mars3d.MaterialType.LineFlicker,
                      materialOptions: {
                        color: "#ffff00",
                        speed: 5,
                      },
                    },
                    zIndex: 5,
                    show: true,
                  });
                  graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)
                } else if (item2.indexOf("))") != -1) {
                  let wkt = item2.split("))")[0].split(", ");
                  let positions = [];
                  wkt.forEach((item1) => {
                    let arr = [item1.split(" ")[0], item1.split(" ")[1]];
                    positions.push(arr);
                  });
                  const graphic2 = new mars3d.graphic.PolylineEntity({
                    positions: positions,
                    style: {
                      width: 5,
                      color: "rgba(255,255,0,.02)",
                      clampToGround: true,
                    },
                    show: true,
                  });
                  graphicLayer.addGraphic(graphic2);
                  const graphic = new mars3d.graphic.PolylineEntity({
                    positions: positions,
                    style: {
                      width: 3,
                      clampToGround: true,
                      materialType: mars3d.MaterialType.LineFlicker,
                      materialOptions: {
                        color: "#ffff00",
                        speed: 1,
                      },
                    },
                    zIndex: 5,
                    show: true,
                  });
                  graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)
                } else {
                  let wkt = item2.split(", ");
                  let positions = [];
                  wkt.forEach((item1) => {
                    let arr = [item1.split(" ")[0], item1.split(" ")[1]];
                    positions.push(arr);
                  });
                  const graphic2 = new mars3d.graphic.PolylineEntity({
                    positions: positions,
                    style: {
                      width: 5,
                      color: "rgba(255,255,0,.02)",
                      clampToGround: true,
                    },
                    show: true,
                  });
                  graphicLayer.addGraphic(graphic2);
                  const graphic = new mars3d.graphic.PolylineEntity({
                    positions: positions,
                    style: {
                      width: 3,
                      clampToGround: true,
                      materialType: mars3d.MaterialType.LineFlicker,
                      materialOptions: {
                        color: "#ffff00",
                        speed: 1,
                      },
                    },
                    zIndex: 5,
                    show: true,
                  });
                  graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)
                }
              }
            }
          }
        });
      }
    }
  });
};

//加载水系
const getWater = async()=>{
      // 动态河流
      // const dynamicRiver = new mars3d.graphic.DynamicRiver({
      //   positions: [
      //     [115.906607, 30.441582, 555.9],
      //     [115.899964, 30.438543, 467.3],
      //     [115.893105, 30.440714, 374.6],
      //     [115.88362, 30.443924, 340.7],
      //     [115.873948, 30.444827, 299],
      //     [115.864003, 30.442111, 292.2],
      //     [115.850741, 30.438108, 189.9]
      //   ],
      //   style: {
      //     image: "//data.mars3d.cn/img/textures/poly-rivers.png",
      //     width: 280,
      //     height: 30,
      //     speed: 10
      //   }
      // })
      //graphicLayer.addGraphic(dynamicRiver)

      //水域加载
      await axios.get("http://172.16.10.83:8085/layer/sx").then((res) => {
          if (res.data.code == "20000000") {
            sxlist.value = res.data.data.list;
            if (sxlist.value.length > 0) {
              let listData = sxlist.value;
              listData.forEach((item) => {
                if (item.wkt) {
                    if (item.wkt.indexOf("))),MULTIPOLYGON (((") == -1) {
                      let wkt = item.wkt
                        .split("MULTIPOLYGON (((")[1]
                        .split(")))")[0]
                        .split(", ");
                      let positions = [];
                      wkt.forEach((item1) => {
                        let arr = [item1.split(" ")[0], item1.split(" ")[
                          1]];
                        positions.push(arr);
                      });
                      const dynamicWater = new mars3d.graphic.Water({
                          positions: positions,
                          style: {
                            normalMap: "/src/assets/imgs/waterNormals.jpg", // 水正常扰动的法线图
                            frequency: 8000.0, // 控制波数的数字。
                            animationSpeed: 0.02, // 控制水的动画速度的数字。
                            amplitude: 5.0, // 控制水波振幅的数字。
                            specularIntensity: 0.8, // 控制镜面反射强度的数字。
                            baseWaterColor: "#006ab4", // rgba颜色对象基础颜色的水。#00ffff,#00baff,#006ab4
                            blendColor: "#006ab4", // 从水中混合到非水域时使用的rgba颜色对象。
                            opacity: 0.7, // 透明度
                            offsetAttribute: Cesium.GeometryOffsetAttribute.ALL, // 需要有
                            offsetHeight: 0,
                            clampToGround: true, // 是否贴地
                        },
                      })
                      graphicLayer.addGraphic(dynamicWater)
                    } else {
                      let pList = item.wkt.split("))),MULTIPOLYGON ((()");
                      for (let i = 0; i < pList.length; i++) {
                        let item2 = pList[i];
                        if (item2.indexOf("MULTIPOLYGON ((") != -1) {
                          let wkt = item2.split("MULTIPOLYGON ((")[1].split(", ");
                          let positions = [];
                          wkt.forEach((item1) => {
                            let arr = [item1.split(" ")[0], item1.split(
                              " ")[1]];
                            positions.push(arr);
                          });
                              const dynamicWater = new mars3d.graphic.Water({
                              positions: positions,
                              style: {
                              normalMap: "/src/assets/imgs/waterNormals.jpg", // 水正常扰动的法线图
                              frequency: 8000.0, // 控制波数的数字。
                              animationSpeed: 0.02, // 控制水的动画速度的数字。
                              amplitude: 5.0, // 控制水波振幅的数字。
                              specularIntensity: 0.8, // 控制镜面反射强度的数字。
                              baseWaterColor: "#006ab4", // rgba颜色对象基础颜色的水。#00ffff,#00baff,#006ab4
                              blendColor: "#006ab4", // 从水中混合到非水域时使用的rgba颜色对象。
                              opacity: 0.7, // 透明度
                              offsetAttribute: Cesium.GeometryOffsetAttribute.ALL, // 需要有
                              offsetHeight: 0,
                              clampToGround: true, // 是否贴地
                            },
                          })
                          graphicLayer.addGraphic(dynamicWater)
                        } else if (item2.indexOf(")))") != -1) {
                          let wkt = item2.split(")))")[0].split(", ");
                          let positions = [];
                          wkt.forEach((item1) => {
                            let arr = [item1.split(" ")[0], item1.split(
                              " ")[1]];
                            positions.push(arr);
                          });
                              const dynamicWater = new mars3d.graphic.Water({
                              positions: positions,
                              style: {
                              normalMap: "/src/assets/imgs/waterNormals.jpg", // 水正常扰动的法线图
                              frequency: 8000.0, // 控制波数的数字。
                              animationSpeed: 0.02, // 控制水的动画速度的数字。
                              amplitude: 5.0, // 控制水波振幅的数字。
                              specularIntensity: 0.8, // 控制镜面反射强度的数字。
                              baseWaterColor: "#006ab4", // rgba颜色对象基础颜色的水。#00ffff,#00baff,#006ab4
                              blendColor: "#006ab4", // 从水中混合到非水域时使用的rgba颜色对象。
                              opacity: 0.7, // 透明度
                              offsetAttribute: Cesium.GeometryOffsetAttribute.ALL, // 需要有
                              offsetHeight: 0,
                              clampToGround: true, // 是否贴地
                            },
                          })
                          graphicLayer.addGraphic(dynamicWater)
                        } else {
                          let wkt = item2.split(", ");
                          let positions = [];
                          wkt.forEach((item1) => {
                            let arr = [item1.split(" ")[0], item1.split(
                              " ")[1]];
                            positions.push(arr);
                          });
                              const dynamicWater = new mars3d.graphic.Water({
                              positions: positions,
                              style: {
                              normalMap: "/src/assets/imgs/waterNormals.jpg", // 水正常扰动的法线图
                              frequency: 8000.0, // 控制波数的数字。
                              animationSpeed: 0.02, // 控制水的动画速度的数字。
                              amplitude: 5.0, // 控制水波振幅的数字。
                              specularIntensity: 0.8, // 控制镜面反射强度的数字。
                              baseWaterColor: "#006ab4", // rgba颜色对象基础颜色的水。#00ffff,#00baff,#006ab4
                              blendColor: "#006ab4", // 从水中混合到非水域时使用的rgba颜色对象。
                              opacity: 0.7, // 透明度
                              offsetAttribute: Cesium.GeometryOffsetAttribute.ALL, // 需要有
                              offsetHeight: 0,
                              clampToGround: true, // 是否贴地
                            },
                          })
                          graphicLayer.addGraphic(dynamicWater)
                        }
                      }
                    }
                  }
              });
            }
          }
        });
};

//加载植被
const wblzb = async()=>{
  graphicLayer2 = new mars3d.layer.GeoJsonLayer({
    name: "植被",
    url: "/src/assets/json/wblzb.json",
    symbol: {
      merge: true,
      styleOptions: {
        fill: true,
        color: "#208a26",
        clampToGround: true,
      }
    },
  })
  map.addLayer(graphicLayer2);


};

//加载ty路网
const getRolad = async()=>{
  await axios.get("http://172.16.10.83:8085/layer/road").then((res) => {
    if (res.data.code == "20000000") {
        roadlist.value = res.data.data.list;
        if (roadlist.value.length > 0) {
          roadlist.value.forEach((item) => {
            if (item.wkt) {
              if (item.wkt.indexOf(")),MULTILINESTRING ((") == -1) {
                let wkt = item.wkt
                  .split("MULTILINESTRING ((")[1]
                  .split("))")[0]
                  .split(", ");
                let positions = [];
                wkt.forEach((item1) => {
                  let arr = [item1.split(" ")[0], item1.split(" ")[1]];
                  positions.push(arr);
                });

                const graphic = new mars3d.graphic.PolylinePrimitive({
                  positions: positions,
                  style: {
                    width: 3,
                    clampToGround: true,
                    materialType: mars3d.MaterialType.LineFlow,
                    materialOptions: {
                      //   color: "#cd8c2f",
                      image: "/src/assets/imgs/lu1.png",
                      speed: 5,
                    },
                  },
                  zIndex: 5,
                });
                graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)
              } else {
                let pList = item.wkt.split(")),MULTILINESTRING ((");
                for (let i = 0; i < pList.length; i++) {
                  let item2 = pList[i];
                  if (item2.indexOf("MULTILINESTRING ((") != -1) {
                    let wkt = item2
                      .split("MULTILINESTRING ((")[1]
                      .split(", ");
                    let positions = [];
                    wkt.forEach((item1) => {
                      let arr = [item1.split(" ")[0], item1.split(" ")[1]];
                      positions.push(arr);
                    });
                    const graphic = new mars3d.graphic.PolylinePrimitive({
                      positions: positions,
                      style: {
                        width: 3,
                        clampToGround: true,
                        materialType: mars3d.MaterialType.LineFlow,
                        materialOptions: {
                          image: "/src/assets/imgs/lu1.png",
                          speed: 5,
                        },
                      },
                      zIndex: 5,
                    });
                    graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)
                  } else if (item2.indexOf("))") != -1) {
                    let wkt = item2.split("))")[0].split(", ");
                    let positions = [];
                    wkt.forEach((item1) => {
                      let arr = [item1.split(" ")[0], item1.split(" ")[1]];
                      positions.push(arr);
                    });
                    const graphic = new mars3d.graphic.PolylinePrimitive({
                      positions: positions,
                      style: {
                        width: 3,
                        clampToGround: true,
                        materialType: mars3d.MaterialType.LineFlow,
                        materialOptions: {
                          image: "/src/assets/imgs/lu1.png",
                          speed: 5,
                        },
                      },
                      zIndex: 5,
                    });
                    graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)
                  } else {
                    let wkt = item2.split(", ");
                    let positions = [];
                    wkt.forEach((item1) => {
                      let arr = [item1.split(" ")[0], item1.split(" ")[1]];
                      positions.push(arr);
                    });
                    const graphic = new mars3d.graphic.PolylinePrimitive({
                      positions: positions,
                      style: {
                        width: 3,
                        clampToGround: true,
                        materialType: mars3d.MaterialType.LineFlow,
                        materialOptions: {
                          image: "/src/assets/imgs/lu1.png",
                          speed: 5,
                        },
                      },
                      zIndex: 5,
                    });
                    graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)
                  }
                }
              }
            }
          });
        }
    }
  });
};

//加载区划
const getGrid = async(qhid)=>{
  console.log(qhid)
  const params ={
    id:qhid
  }
await axios.get("http://172.16.10.83:8085/grid/list",{params}).then((res) => {
    if (res.data.code == "20000000") {
        qhlist.value = res.data.data.list
        if(qhlist.value.length>0){
            qhlist.value.forEach((item, index) => {
            if (item.name == "万柏林区") {
                
            } else if (item.name.indexOf("街办") != -1) {
              let pointNew = item.point.split(",");
              if (item.wkt) {
                if (item.wkt.indexOf("))),MULTIPOLYGON (((") == -1) {
                  let wkt = item.wkt
                    .split("MULTIPOLYGON (((")[1]
                    .split(")))")[0]
                    .split(", ");
                  let positions = [];
                  wkt.forEach((item1) => {
                    let arr = [item1.split(" ")[0], item1.split(" ")[1]];
                    positions.push(arr);
                  });
                  const graphic = new mars3d.graphic.ScrollWall({
                    map3d: item.map3d,
                    point: item.point,
                    name: item.name,
                    Newid: item.id,
                    positions: positions,
                    style: {
                      clampToGround: true,
                      diffHeight: 100, // 高度
                      color: "rgba(255,0, 0,1)",
                      speed: 30,
                      reverse: false, // 方向:true往上、false往下
                    },
                    show: false,
                  });
                  graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)
      
                } else {
                  let pList = item.wkt.split("))),MULTIPOLYGON (((");
                  for (let i = 0; i < pList.length; i++) {
                    let item2 = pList[i];
                    if (item2.indexOf("MULTIPOLYGON (((") != -1) {
                      let wkt = item2
                        .split("MULTIPOLYGON (((")[1]
                        .split(", ");
                      let positions = [];
                      wkt.forEach((item1) => {
                        let arr = [item1.split(" ")[0], item1.split(" ")[1]];
                        positions.push(arr);
                      });
                      const graphic = new mars3d.graphic.ScrollWall({
                        map3d: item.map3d,
                        point: item.point,
                        name: item.name,
                        Newid: item.id,
                        positions: positions,
                        style: {
                          clampToGround: true,
                          diffHeight: 100, // 高度
                          color: "rgba(255,0, 0,1)",
                          speed: 30,
                          reverse: false, // 方向:true往上、false往下
                        },
                        show: false,
                      });
                      graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)
        
                    } else if (item2.indexOf(")))") != -1) {
                      let wkt = item2.split(")))")[0].split(", ");
                      let positions = [];
                      wkt.forEach((item1) => {
                        let arr = [item1.split(" ")[0], item1.split(" ")[1]];
                        positions.push(arr);
                      });
                      const graphic = new mars3d.graphic.ScrollWall({
                        map3d: item.map3d,
                        point: item.point,
                        name: item.name,
                        Newid: item.id,
                        positions: positions,
                        style: {
                          clampToGround: true,
                          diffHeight: 100, // 高度
                          color: "rgba(255,0, 0,1)",
                          speed: 30,
                          reverse: false, // 方向:true往上、false往下
                        },
                        show: false,
                      });
                      graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)
                      
                    } else {
                      let wkt = item2.split(", ");
                      let positions = [];
                      wkt.forEach((item1) => {
                        let arr = [item1.split(" ")[0], item1.split(" ")[1]];
                        positions.push(arr);
                      });
                      const graphic = new mars3d.graphic.ScrollWall({
                        map3d: item.map3d,
                        point: item.point,
                        name: item.name,
                        Newid: item.id,
                        positions: positions,
                        style: {
                          clampToGround: true,
                          diffHeight: 100, // 高度
                          color: "rgba(255,0, 0,1)",
                          speed: 30,
                          reverse: false, // 方向:true往上、false往下
                        },
                        show: false,
                      });
                      graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)
                      
                    }
                  }
                }
              }
              let point = item.point.split(",");
              const graphicName = new mars3d.graphic.BillboardEntity({
                map3d: item.map3d,
                // point: item.point,//会绘制一个白点
                name: item.name,
                Newid: item.id,
                position: [point[1], point[0], 1000],
                style: {
                  image: "/src/assets/imgs/11.png",
                  scale: self.big ? 0.1 : 0.08,
                  horizontalOrigin: Cesium.HorizontalOrigin.CENTER,
                  verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
                  label: {
                    visibleDepth: false,
                    text: item.name,
                    pixelOffsetY: self.big ? -90 : -70,
                    pixelOffsetX: 0,
                    font_size: self.big ? 35 : 20,
                    color: "#fff",
                    outline: true,
                    outlineColor: "#000000",
                    outlineWidth: 8,
                  },
                  clampToGround: false,
                },
                // 高亮时的样式(默认为鼠标移入,也可以指定type:'click'单击高亮),构造后也可以openHighlight、closeHighlight方法来手动调用

              });
              graphicLayer.addGraphic(graphicName);
              
            } else if (
              item.name.indexOf("社区") != -1 &&
              item.name.indexOf("网格") == -1
            ) {
              if (item.wkt) {
                if (item.wkt.indexOf("))),MULTIPOLYGON (((") == -1) {
                  let wkt = item.wkt
                    .split("MULTIPOLYGON (((")[1]
                    .split(")))")[0]
                    .split(", ");
                  let positions = [];
                  wkt.forEach((item1) => {
                    let arr = [item1.split(" ")[0], item1.split(" ")[1], 770];
                    positions.push(arr);
                  });

                  const graphic = new mars3d.graphic.WallEntity({
                    map3d: item.map3d,
                    point: item.point,
                    name: item.name,
                    Newid: item.id,
                    positions: positions,
                    style: {
                      diffHeight: 20, // 高度
                      materialType: mars3d.MaterialType.WallScroll,
                      materialOptions: {
                        image: "/src/assets/imgs/flow-wall-4.png",
                        color: "rgba(3, 104, 255,0.5)",
                        count: 1,
                        speed: 20,
                        bloom: true,
                      },
                    },
                    zIndex: 5,
                    show: false,
                  });
                  graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)

                } else {
                  let pList = item.wkt.split("))),MULTIPOLYGON (((");
                  for (let i = 0; i < pList.length; i++) {
                    let item2 = pList[i];
                    if (item2.indexOf("MULTIPOLYGON (((") != -1) {
                      let wkt = item2
                        .split("MULTIPOLYGON (((")[1]
                        .split(", ");
                      let positions = [];
                      wkt.forEach((item1) => {
                        let arr = [
                          item1.split(" ")[0],
                          item1.split(" ")[1],
                          770,
                        ];
                        positions.push(arr);
                      });
                      const graphic = new mars3d.graphic.WallEntity({
                        map3d: item.map3d,
                        point: item.point,
                        name: item.name,
                        Newid: item.id,
                        positions: positions,
                        style: {
                          diffHeight: 20, // 高度
                          materialType: mars3d.MaterialType.WallScroll,
                          materialOptions: {
                            image: "/src/assets/imgs/flow-wall-4.png",
                            color: "rgba(3, 104, 255,0.5)",
                            count: 1,
                            speed: 20,
                            bloom: true,
                          },
                        },
                        zIndex: 5,
                        show: false,
                      });
                      graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)

                    } else if (item2.indexOf(")))") != -1) {
                      let wkt = item2.split(")))")[0].split(", ");
                      let positions = [];
                      wkt.forEach((item1) => {
                        let arr = [
                          item1.split(" ")[0],
                          item1.split(" ")[1],
                          770,
                        ];
                        positions.push(arr);
                      });
                      const graphic = new mars3d.graphic.WallEntity({
                        map3d: item.map3d,
                        point: item.point,
                        name: item.name,
                        Newid: item.id,
                        positions: positions,
                        style: {
                          diffHeight: 20, // 高度
                          materialType: mars3d.MaterialType.WallScroll,
                          materialOptions: {
                            image: "/src/assets/imgs/flow-wall-4.png",
                            color: "rgba(3, 104, 255,0.5)",
                            count: 1,
                            speed: 20,
                            bloom: true,
                          },
                        },
                        zIndex: 5,
                        show: false,
                      });
                      graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)

                    } else {
                      let wkt = item2.split(", ");
                      let positions = [];
                      wkt.forEach((item1) => {
                        let arr = [
                          item1.split(" ")[0],
                          item1.split(" ")[1],
                          770,
                        ];
                        positions.push(arr);
                      });
                      const graphic = new mars3d.graphic.WallEntity({
                        map3d: item.map3d,
                        point: item.point,
                        name: item.name,
                        Newid: item.id,
                        positions: positions,
                        style: {
                          diffHeight: 20, // 高度
                          materialType: mars3d.MaterialType.WallScroll,
                          materialOptions: {
                            image: "/src/assets/imgs/flow-wall-4.png",
                            color: "rgba(3, 104, 255,0.5)",
                            count: 1,
                            speed: 20,
                            bloom: true,
                          },
                        },
                        zIndex: 5,
                        show: false,
                      });
                      graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)

                    
                    }
                  }
                }
              }
              let point = item.point.split(",");
              const graphicName = new mars3d.graphic.BillboardEntity({
                map3d: item.map3d,
                //point: item.point,
                name: item.name,
                Newid: item.id,
                position: [point[1], point[0], 870],
                style: {
                  image: "/src/assets/imgs/8.png",
                  scale: self.big ? 0.5 : 0.3,
                  horizontalOrigin: Cesium.HorizontalOrigin.CENTER,
                  verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
                  // perPositionHeight: true,
                  label: {
                    visibleDepth: false,
                    text: item.name,
                    pixelOffsetY: self.big ? -210 : -115,
                    pixelOffsetX: 10,
                    font_size: self.big ? 35 : 20,
                    color: "#fff",
                    // perPositionHeight: true
                  },
                  // 高亮时的样式(默认为鼠标移入,也可以指定type:'click'单击高亮),构造后也可以openHighlight、closeHighlight方法来手动调用
                },
              });
              graphicLayer.addGraphic(graphicName);
              // if (graphicName.startBounce) {
              //   graphicName.startBounce({
              //     maxHeight: 10,
              //     step: 0.3,
              //   });
              // }
              // self.sqList.push(graphicName);
            } else {
              if (item.wkt) {
                if (item.wkt.indexOf("))),MULTIPOLYGON (((") == -1) {
                  let wkt = item.wkt
                    .split("MULTIPOLYGON (((")[1]
                    .split(")))")[0]
                    .split(", ");
                  let positions = [];
                  wkt.forEach((item1) => {
                    let arr = [item1.split(" ")[0], item1.split(" ")[1]];
                    positions.push(arr);
                  });
                  const graphic = new mars3d.graphic.WallEntity({
                    map3d: item.map3d,
                    point: item.point,
                    name: item.name,
                    Newid: item.id,
                    positions: positions,
                    style: {
                      materialType: mars3d.MaterialType.WallScroll,
                      materialOptions: {
                        image: "/src/assets/imgs/fence.png",
                        color: "rgba(154, 255, 0,1)",
                        count: 3,
                        speed: 20,
                        bloom: true,
                      },
                    },
                    zIndex: 5,
                  });
                  graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)
          
                } else {
                  let pList = item.wkt.split("))),MULTIPOLYGON (((");
                  for (let i = 0; i < pList.length; i++) {
                    let item2 = pList[i];
                    if (item2.indexOf("MULTIPOLYGON (((") != -1) {
                      let wkt = item2
                        .split("MULTIPOLYGON (((")[1]
                        .split(", ");
                      let positions = [];
                      wkt.forEach((item1) => {
                        let arr = [item1.split(" ")[0], item1.split(" ")[1]];
                        positions.push(arr);
                      });
                      const graphic = new mars3d.graphic.WallEntity({
                        map3d: item.map3d,
                        point: item.point,
                        name: item.name,
                        Newid: item.id,
                        positions: positions,
                        style: {
                          materialType: mars3d.MaterialType.WallScroll,
                          materialOptions: {
                            image: "/src/assets/imgs/fence.png",
                            color: "rgba(154, 255, 0,1)",
                            count: 3,
                            speed: 20,
                            bloom: true,
                          },
                        },
                        zIndex: 5,
                      });
                      graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)
                    
                    } else if (item2.indexOf(")))") != -1) {
                      let wkt = item2.split(")))")[0].split(", ");
                      let positions = [];
                      wkt.forEach((item1) => {
                        let arr = [item1.split(" ")[0], item1.split(" ")[1]];
                        positions.push(arr);
                      });
                      const graphic = new mars3d.graphic.WallEntity({
                        map3d: item.map3d,
                        point: item.point,
                        name: item.name,
                        Newid: item.id,
                        positions: positions,
                        style: {
                          materialType: mars3d.MaterialType.WallScroll,
                          materialOptions: {
                            image: "/src/assets/imgs/fence.png",
                            color: "rgba(154, 255, 0,1)",
                            count: 3,
                            speed: 20,
                            bloom: true,
                          },
                        },
                        zIndex: 5,
                      });
                      graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)
                      
                    } else {
                      let wkt = item2.split(", ");
                      let positions = [];
                      wkt.forEach((item1) => {
                        let arr = [item1.split(" ")[0], item1.split(" ")[1]];
                        positions.push(arr);
                      });
                      const graphic = new mars3d.graphic.WallEntity({
                        map3d: item.map3d,
                        point: item.point,
                        name: item.name,
                        Newid: item.id,
                        positions: positions,
                        style: {
                          materialType: mars3d.MaterialType.WallScroll,
                          materialOptions: {
                            image: "/src/assets/imgs/fence.png",
                            color: "rgba(154, 255, 0,1)",
                            count: 3,
                            speed: 20,
                            bloom: true,
                          },
                        },
                        zIndex: 5,
                      });
                      graphicLayer.addGraphic(graphic); // 还可以另外一种写法: graphic.addTo(graphicLayer)
            
                    }
                  }
                }
              }

              let point = item.point.split(",");
              const graphicName = new mars3d.graphic.BillboardEntity({
                map3d: item.map3d,
                point: item.point,
                name: item.name.split("区")[1],
                Newid: item.id,
                position: [point[1], point[0], 820],
                style: {
                  image: "/src/assets/imgs/wg.png",
                  scale: self.big ? 1 : 0.3,
                  horizontalOrigin: Cesium.HorizontalOrigin.CENTER,
                  verticalOrigin: Cesium.VerticalOrigin.BOTTOM,
                  // perPositionHeight: true,
                  label: {
                    visibleDepth: false,
                    text: item.name.split("区")[1],
                    pixelOffsetY: self.big ? -240 : -73,
                    pixelOffsetX: 0,
                    font_size: self.big ? 50 : 15,
                    color: "#fff",
                  },
                  // 高亮时的样式(默认为鼠标移入,也可以指定type:'click'单击高亮),构造后也可以openHighlight、closeHighlight方法来手动调用
                },
              });
              graphicLayer.addGraphic(graphicName);
              // if (graphicName.startBounce) {
              //   graphicName.startBounce({
              //     maxHeight: 10,
              //     step: 0.3,
              //   });
              // }
              // self.wgList.push(graphicName);
            }

            if (item.name == "万柏林区") {
              console.log("item.name == '万柏林区'")
              getGrid(item.id);
            }
          });
        }
    }
  });
};

//设置事件监听
const setEvent = () =>{
  map.on([mars3d.EventType.click], function (e) {
      if (
        e.graphic.options.name != "万柏林区" &&
        e.graphic.options.name != "楼栋" &&
        e.graphic.options.name != "房屋"
      ) {
        row({
          name: e.graphic.options.name,
          id: e.graphic.options.Newid,
          point: e.graphic.options.position,
          map3d: e.graphic.options.map3d,
          type: "none",
        });

        
      } else {
        // if (e.graphic.options.name == "楼栋") {
        //   Map.wblDt(e.graphic.options);
        // }
        // if (e.graphic.options.name == "房屋") {
        //   self.isRoomPopup = true;
        //   setTimeout(() => {
        //     bus.$emit("setBuildingDate", e.graphic.options.newName);
        //   }, 500);
        // }
      }
    });
    
}

//视角移动
const row = (item)=>{
    if (item.name != "万柏林区") {
    let point = item.point;
    let hei = 3000;
    if (
      item.name.indexOf("小区") != -1 ||
      item.name.indexOf("楼栋") != -1
    ) {
      hei = 1500;
    }
    map.flyToPoint(new mars3d.LngLatPoint(point[0], point[1]), {
      radius: hei,
      heading: item.heading ? item.heading : 343,
      pitch: item.pitch ? item.pitch : -18,
      alt: item.alt ? item.alt : 0,
      roll: 0,
      clampToGround: true,
    });
    if (item.name.indexOf("街办") != -1) {
      getGrid(item.id);
    } else if (
      item.name.indexOf("社区") != -1 &&
      item.name.indexOf("网格") == -1
    ) {

      tiles3dLayer1.show = false;//清除白膜

      tileLayer = new mars3d.layer.TdtLayer({
        name: "天地图影像底图",
        layer: "img_d",
      });
      map.addLayer(tileLayer);
        if (item.map3d) {

          // 模型
          tiles3dLayer2 = new mars3d.layer.TilesetLayer({
            name: "社区",
            url: "http://172.16.10.83:9509/map3d" + item.map3d,
            position: {
              alt_offset: -10
            },
            maximumScreenSpaceError: 16, //【重要】数值加大,能让最终成像变模糊
            zIndex: 3,
            show: true,
          });
         map.addLayer(tiles3dLayer2);
        }



      // if (this.isDt != "影像地图") {
      //   this.setLayer("y");
      //   this.isDt = "影像地图";
      // }

      // this.activeWgId = null;
      // this.ldId = null;
      // if (this.xqList.length > 0) {
      //   let arr = this.xqList;
      //   for (let i = 0; i < arr.length; i++) {
      //     window.$drawControl.removeGraphic(arr[i], true);
      //     arr.splice(i, 1);
      //     //重置i,否则i会跳一位
      //     i--;
      //   };
      //   this.xqList = [];
      // }
      // this.wgLists = [];
      // if (this.wgList.length > 0) {
      //   let arr = this.wgList;
      //   for (let i = 0; i < arr.length; i++) {
      //     window.$drawControl.removeGraphic(arr[i], true);
      //     arr.splice(i, 1);
      //     //重置i,否则i会跳一位
      //     i--;
      //   };
      //   this.wgList = [];
      // }
      // if (this.ldList.length > 0) {
      //   let arr = this.ldList;
      //   for (let i = 0; i < arr.length; i++) {
      //     window.$drawControl.removeGraphic(arr[i], true);
      //     arr.splice(i, 1);
      //     //重置i,否则i会跳一位
      //     i--;
      //   };
      //   this.ldList = [];
      // }
      // if (this.roomList.length > 0) {
      //   let arr = this.roomList;
      //   for (let i = 0; i < arr.length; i++) {
      //     window.$drawControl.removeGraphic(arr[i], true);
      //     arr.splice(i, 1);
      //     //重置i,否则i会跳一位
      //     i--;
      //   };
      //   this.roomList = [];
      // }
      // if (this.zbList.length > 0) {
      //   let arr = this.zbList;
      //   for (let i = 0; i < arr.length; i++) {
      //     window.$viewer.removeLayer(arr[i], true);
      //     arr.splice(i, 1);
      //     //重置i,否则i会跳一位
      //     i--;
      //   };
      //   this.zbList = [];
      // }
      // console.log(this.activesQId)
      // console.log(item.id)
      // if (this.activesQId != item.id) {
      //   if (this.titlesListSq.length > 0) {
      //     let arr = this.titlesListSq;
      //     console.log(arr)
      //     for (let i = 0; i < arr.length; i++) {
      //       console.log(arr[i])
      //       window.$viewer.removeLayer(arr[i], true);
      //       arr.splice(i, 1);
      //       //重置i,否则i会跳一位
      //       i--;
      //     };
      //     this.titlesListSq = [];
      //   }
      //   let arr1 = this.titlesList;
      //   for (let i = 0; i < arr1.length; i++) {
      //     window.$viewer.removeLayer(arr1[i], true);
      //     arr1.splice(i, 1);
      //     //重置i,否则i会跳一位
      //     i--;
      //   };

      //   this.titlesList = []
      //   if (item.map3d) {

      //     // 模型
      //     let tiles3dLayer = new EGLOBE.layer.TilesetLayer({
      //       name: "社区",
      //       url: this.tileset + item.map3d,
      //       position: {
      //         alt_offset: -10
      //       },
      //       maximumScreenSpaceError: 256, //【重要】数值加大,能让最终成像变模糊
      //       zIndex: 3,
      //       show: true,

      //       cacheBytes: 4096 * 1024 * 1024, // 1024MB = 1024*1024*1024 【重要】额定显存大小(以字节为单位),允许在这个值上下波动。
      //       maximumCacheOverflowBytes: 6144 * 1024 * 1024, // 2048MB = 2048*1024*1024 【重要】最大显存大小(以字节为单位)。
      //       skipLevelOfDetail: true,
      //       baseScreenSpaceError: 1024,
      //       skipScreenSpaceErrorFactor: 16,
      //       skipLevels: 1,
      //       immediatelyLoadDesiredLevelOfDetail: false,
      //       loadSiblings: false, // 如果为true则不会在已加载完概况房屋后,自动从中心开始超清化房屋
      //       cullWithChildrenBounds: true,
      //       cullRequestsWhileMoving: true,
      //       cullRequestsWhileMovingMultiplier: 10, //【重要】 值越小能够更快的剔除
      //       preloadWhenHidden: true,
      //       preferLeaves: true,
      //       progressiveResolutionHeightFraction: 1, //【重要】 数值偏于0能够让初始加载变得模糊
      //       // dynamicScreenSpaceErrorDensity: 0.1, // 数值加大,能让周边加载变快
      //       dynamicScreenSpaceErrorDensity: 1, // 数值加大,能让周边加载变快
      //       dynamicScreenSpaceErrorFactor: 1, // 不知道起了什么作用没,反正放着吧先
      //       dynamicScreenSpaceError: false, // 根据测试,有了这个后,会在真正的全屏加载完之后才清晰化房屋
      //       preloadWhenHidden: true,
      //       flat: item.flat ? item.flat : {}
      //     });
      //    view.addLayer(tiles3dLayer);
      //     this.titlesListSq.push(tiles3dLayer);
      //     setTimeout(() => {
      //       self.sqList.forEach(item => {
      //         item.show = true;
      //       })
      //     }, 5000)
      //   }
      // }
      // this.activesQId = item.id;
      // this.getEstateLists(item.id);
      // this.getBuildinglists(item.id);
    } else if (item.name.indexOf("小区") != -1) {


    } else if (item.name.indexOf("楼栋") != -1) {
      // if (this.shuixi.length > 0) {
      //   let arr1 = this.shuixi;
      //   for (let i = 0; i < arr1.length; i++) {
      //     window.$drawControl.removeGraphic(arr1[i], true);
      //     arr1.splice(i, 1);
      //     //重置i,否则i会跳一位
      //     i--;
      //   };

      //   this.shuixi = [];
      // }
      // if (this.road.length > 0) {
      //   let arr1 = this.road;
      //   for (let i = 0; i < arr1.length; i++) {
      //     window.$drawControl.removeGraphic(arr1[i], true);
      //     arr1.splice(i, 1);
      //     //重置i,否则i会跳一位
      //     i--;
      //   };
      //   this.road = [];
      // }
      // if (this.ldId != item.id) {
      //   this.ldId = item.id;
      //   if (this.roomList.length > 0) {
      //     let arr1 = this.roomList;
      //     for (let i = 0; i < arr1.length; i++) {
      //       window.$drawControl.removeGraphic(arr1[i], true);
      //       arr1.splice(i, 1);
      //       //重置i,否则i会跳一位
      //       i--;
      //     };
      //     this.roomList = [];
      //   }
      //   this.getRoomlists(item.id);
      // }
    } else {
      //this.activeWgId = item.id;
    }

  }
}
</script>

<template>
  <div id="mars3dContainer" class="mars3dBox"></div>
</template>

<style scoped>
.mars3dBox {
  width: 100%;
  height: 100%;
}
</style>
相关推荐
cxr8286 小时前
如何制定有效的微调策略
llama·cesium·unsloth
无法长大13 小时前
el-upload on-preview 扩大预览事件点击范围
前端·javascript·css·vue.js·elementui·vue
紫云_Zyun1 天前
JAVA开发学习Day8
java·开发语言·学习·vue
蔚一1 天前
运行npm install 时,卡在sill idealTree buildDeps没有反应
前端·spring boot·后端·npm·node.js·vue
番茄小酱0011 天前
select下拉框,首次进入页面没有显示value的情况
前端·javascript·vue.js·vue
公子小黑1 天前
为某一地区制作cesium地形数据
gis·cesium
xChive1 天前
解决 uniapp 开发中的相机相册权限申请同步告知目的问题(兼容 Android 13)| 华为应用商店上架解决方案
android·uni-app·vue
寻找09之夏1 天前
【Vue】:解决动态更新 <video> 标签 src 属性后视频未刷新的问题
vue·视频
风月歌2 天前
java项目之旅游网站的设计与实现(源码+文档)
java·mysql·vue·源码·springboot