浏览代码

Merge branch 'master' of http://www.sysuimars.cn:3000/feiniao/feiniao-pc-vue

wangsisi 4 月之前
父节点
当前提交
34715ce4a9

二进制
public/arrow.png


二进制
public/blue_icon.png


二进制
public/green_icon.png


二进制
public/orange_icon.png


二进制
public/point1.png


二进制
public/point2.png


二进制
public/point3.png


二进制
public/point4.png


二进制
public/point5.png


二进制
public/point6.png


二进制
public/point7.png


二进制
public/point8.png


二进制
public/xy4000.png


二进制
public/xy6000.png


二进制
public/xy8000.png


+ 1 - 1
src/api/config.js

@@ -1,3 +1,4 @@
+// let server = "http://127.0.0.1:81/";
 let server = "https://birdseye-api.feiniaotech.sysuimars.cn/"
 let mapServer = "https://birdseye-api.sysuimars.cn/"
 let serverMock = "https://mock.apipark.cn/m1/4662471-4313509-default/"
@@ -10,7 +11,6 @@ module.exports = {
     base_map_url: mapServer + "mini/",
     dji_cloud_base :djiCloudBase,
     image_url:server+"images/",
-    base_img_url : "https://img.sysuimars.com/",
     base_img_url2 : "https://birdseye-img-ali-cdn.sysuimars.com/",
     base_img_url3 : "https://birdseye-img.sysuimars.com/",
     base_video_url : "https://minio.sysuimars.com/sysuimars/",

+ 0 - 48
src/api/modules/config.js

@@ -1,48 +0,0 @@
-const config = require("../config")
-
-const legend = [
-
-    //作物分布图例 0
-    [{"name":"荔枝", "color":"#005BE7"},{"name":"龙眼", "color":"#01A884"},{"name":"化橘红", "color":"#ED0911"},{"name":"三化李", "color":"#A7A700"},],
-    //作物分布图例 1
-    [{"name":"开花期", "color":"#98E500"},{"name":"生理落果期", "color":"#D9E714"},{"name":"果实发育期", "color":"#DEAC00"},{"name":"果实成熟期", "color":"#E34D00"}],
-    //土壤墒情 2
-    [{"name":"一级", "color":"#E84335"},{"name":"二级", "color":"#18E6F6"},{"name":"三级", "color":"#653AA7"},{"name":"四级", "color":"#1469F7"},{"name":"五级", "color":"#799A85"},],
-    //温度分布 3
-    [{"name":"> 30C°", "color":"#E52B31"},{"name":"20C°~30C°", "color":"#AE8100"},{"name":"10C°~20C°", "color":"#49B000"},{"name":"< 10C°", "color":"#666FF0"},],
-
-    //气象图例 4无风险、低风险,中风险,高风险,极高风险
-    [{"name":"无风险", "color":"#2892C6"},{"name":"低风险", "color":"#78BAA6"},{"name":"中风险", "color":"#F2F134"},{"name":"高风险", "color":"#EC6944"},{"name":"极高风险", "color":"#B40404"}],
-
-    //病虫害分布 5
-    [{"name":"无风险", "color":"#56556C"},{"name":"低风险", "color":"#8DB8A4"},{"name":"中风险", "color":"#D9E27F"},{"name":"高风险", "color":"#F5CF49"},{"name":"极高风险", "color":"#F87A2D"},{"name":"已病害", "color":"#E71413"}],
-
-    //荔枝品种分布图例 6
-    [{"name":"未知", "color":"point6.png"},{"name":"桂味", "color":"point1.png"},{"name":"槐枝", "color":"point2.png"},{"name":"井岗红糯", "color":"point3.png"},{"name":"糯米糍", "color":"point4.png"},{"name":"岭丰糯", "color":"point5.png"},],
-
-    //农事 7
-    [{"name":"已喷药", "color":"action_py.png"},{"name":"已施肥", "color":"action_sf.png"},
-        {"name":"待喷药", "color":"action_stay_py.png"},{"name":"待施肥", "color":"action_stay_sf.png"},],
-    //效益 8
-    [{"name":">80斤", "color":"xy8000.png"},{"name":"40~80斤", "color":"xy6000.png"},
-        {"name":"<40斤", "color":"xy4000.png"},],
-
-]
-
-
-function getLegend(id){
-    return legend[id];
-}
-
-
-module.exports = {
-    legend: {
-        url: "/legend",
-        type: "post",
-        mock: true,
-        response: (opt) => {
-            let body = config.getOptBody(opt);
-            return getLegend(body.id);
-        },
-    },
-}

+ 0 - 16
src/api/modules/dict.js

@@ -1,16 +0,0 @@
-const config = require("../config")
-
-
-
-
-module.exports = {
-    list: {
-        url: config.base_url + "dict/list",
-        type: "get",
-    },
-    save: {
-        url: config.base_url + "dict/save",
-        type: "post",
-    },
-
-}

+ 0 - 21
src/api/modules/dji_control.js

@@ -1,21 +0,0 @@
-const config = require("../config")
-const base = config.dji_cloud_base + "control/api/v1/devices/";
-const waylineBase = config.dji_cloud_base + "wayline/api/v1/workspaces/";
-
-
-
-module.exports = {
-    takeoffToPoint: {
-        url: base + "{sn}/jobs/takeoff-to-point",
-        type: "post",
-    },
-    createJob: {
-        url: waylineBase + "{workspaceId}/flight-tasks",
-        type: "post",
-    },
-    save: {
-        url: config.dji_cloud_base + "dict/save",
-        type: "post",
-    },
-
-}

+ 0 - 54
src/api/modules/lzxt.js

@@ -1,54 +0,0 @@
-const config = require("../config")
-
-module.exports = {
-    areaPartList:{
-        url: config.base_url + "lz_area_part/list",
-        type:"get"
-    },
-    lzAreaList: {
-        url: config.base_url + "lz_area/list",
-        type: "post",
-    },
-    lzAreaSave: {
-        url: config.base_url + "lz_area/save",
-        type: "post",
-    },
-    changePeriod: {
-        url: config.base_url + "lz_area/changePeriod",
-        type: "post",
-    },
-    lzGroupList: {
-        url: config.base_url + "lz_group/list",
-        type: "post",
-    },
-    lzGroupSave: {
-        url: config.base_url + "lz_group/save",
-        type: "post",
-    },
-    lzTreeList: {
-        url: config.base_url + "lz_tree/list",
-        type: "post",
-    },
-    lzTreeSave: {
-        url: config.base_url + "lz_tree/save",
-        type: "post",
-    },
-    lzTreeUpdate: {
-        url: config.base_url + "lz_tree/update",
-        type: "post",
-    },
-    uploadData: {
-        url: config.base_url + "lz_everyday/updateData",
-        type: "post",
-    },
-    //物候期列表
-    periodList: {
-        url: config.base_url + "lz_period/list",
-        type: "post",
-    },
-    airRoute: {
-        url: config.base_url + "lz_air_route/air_route",
-        type: "post",
-    }
-
-}

+ 0 - 40
src/api/modules/nsjy.js

@@ -1,40 +0,0 @@
-const config = require("../config")
-
-
-
-
-module.exports = {
-    nsTypeList: {
-        url: config.base_url + "ns_type/list",
-        type: "get",
-    },
-    userList:{
-        url: config.base_url + "user/user_list",
-        type: "post",
-    },
-    getNsRecord:{
-        url: config.base_url + "ns_record/get",
-        type: "get",
-    },
-    save:{
-        url: config.base_url + "ns_record/save",
-        type: "post",
-    },
-    updateStatus:{
-        url: config.base_url + "ns_record/updateStatus/{id}/{status}",
-        type: "get",
-    },
-    sendStayExecute:{
-        url: config.base_url + "ns_record/sendStayExecute",
-        type: "post",
-    },
-    page:{
-        url: config.base_url + "ns_record/page/{limit}/{page}",
-        type: "post",
-    },
-    remove:{
-        url: config.base_url + "ns_record/remove",
-        type: "get",
-    }
-
-}

+ 0 - 24
src/api/modules/organ.js

@@ -1,24 +0,0 @@
-const config = require("../config")
-
-
-
-
-module.exports = {
-    getOrganExplain: {
-        url: config.base_url + "sys_organ_explain/get",
-        type: "get",
-    },
-    listOrganExplain: {
-        url: config.base_url + "sys_organ_explain/list",
-        type: "get",
-    },
-    gardenData: {
-        url: config.base_url + "home/garden/list",
-        type: "get",
-    },
-    updateGarden: {
-        url: config.base_url + "home/garden/update/{gardenId}",
-        type: "get",
-    },
-
-}

+ 11 - 0
src/api/modules/region.js

@@ -0,0 +1,11 @@
+//采样点接口
+const config = require("../config")
+
+
+
+module.exports = {
+    list: {
+        url: config.base_url + "region/list",
+        type: "post",
+    },
+}

+ 11 - 0
src/api/modules/sample.js

@@ -0,0 +1,11 @@
+//采样点接口
+const config = require("../config")
+
+
+
+module.exports = {
+    list: {
+        url: config.base_url + "lz_sample/list",
+        type: "post",
+    },
+}

+ 0 - 8
src/api/modules/system.js

@@ -22,10 +22,6 @@ module.exports = {
         url: config.base_url + "cfg/get",
         type: "post",
     },
-    getDeviceReceiverByAreaId: {
-        url: config.base_url + "deviceReceiver/getByAreaId/{areaId}",
-        type: "post",
-    },
     weather:{
         url:config.base_url + "lz_weather7d/get/{organId}",
         type:"get"
@@ -38,10 +34,6 @@ module.exports = {
         url: config.base_url + "town/dropdown",
         type:"get"
     },
-    areaList:{
-        url: config.base_url + "lz_area/list",
-        type:"get"
-    },
     getTown:{
         url: config.base_url + "town/get",
         type:"get"

+ 0 - 45
src/api/modules/tree.js

@@ -1,45 +0,0 @@
-const config = require("../config")
-
-
-
-module.exports = {
-    page:{
-        url: config.base_url + "lz_tree/page/{organId}/{areaId}",
-        type: "get",
-    },
-    treeList:{
-        url: config.base_url + "lz_tree/list",
-        type: "get",
-    },
-    treeListAndGrowData:{
-        url: config.base_url + "lz_tree/treeListAndGrowData/{organId}/{areaId}",
-        type: "post",
-    },
-    imgList: {
-        url: config.base_url + "lz_tree_image/list",
-        type: "get",
-    },
-    //生长数据列表
-    treeGrowData: {
-        url: config.base_url + "tree_grow_data/info",
-        // mock: false,
-        type: "post",
-        // response:(opt)=>{
-        //     return treeGrowData;
-        // }
-    },
-    //农事数据列表
-    siteList: {
-        url: config.base_url + "ns_record/page",
-        type: "post",
-        // mock:false,
-        // response:(opt)=>{
-        //     return rongShi;
-        // }
-    },
-    //农事类型
-    nongShiList:{
-        url: config.base_url + "ns_type/list",
-        type: "get",
-    }
-}

+ 0 - 47
src/api/modules/znxy.js

@@ -1,47 +0,0 @@
-/*
- * @Author: your name
- * @Date: 2021-02-07 13:40:50
- * @LastEditTime: 2021-12-02 15:59:52
- * @LastEditors: Please set LastEditors
- * @Description: In User Settings Edit
- * @FilePath: \vue3-element-admin\src\api\modules\system.js
- */
-// const Mock = require("mockjs"); //引入
-const config = require("../config")
-
-module.exports = {
-    baseInfo: {
-        url: config.base_url + "home/base-info/{gardenId}",
-        type: "get",
-    },
-    weatherWarning: {
-        url: config.base_url + "home/weather-warning/{gardenId}",
-        type: "get",
-    },
-    outputCalc: {
-        url: config.base_url + "home/output-calc/{gardenId}",
-        type: "get",
-    },
-    growAbnormal: {
-        url: config.base_url + "home/grow-abnormal/{gardenId}",
-        type: "get",
-    },
-    pestAbnormal: {
-        url: config.base_url + "home/pest-abnormal/{gardenId}",
-        type: "get",
-    },
-    pestStatistics: {
-        url: config.base_url + "home/pest-statistics/{gardenId}/{warningType}",
-        type: "get",
-    },
-    // 生长态势图例
-    szLegend: {
-        url: config.base_url + "lz_period_progress/list/{periodId}",
-        type: "get",
-    },
-    // 生长态势数据
-    szList: {
-        url: config.base_url + "home/grow-statistics/{gardenId}",
-        type: "get",
-    },
-};

+ 2 - 0
src/utils/ol-map/Map.js

@@ -120,6 +120,8 @@ class Map {
 	  const cva_wmts = await VE_API.system.getCfg({"k":"cva_wmts_mkt","resultType":"json"});
 	  this.tdtImgLayer = new WMTSLayer(img_wmts.data, projection,this);
 	  this.cva_torLayer = new  WMTSLayer(cva_wmts.data,projection,this);
+	  let xyz2 = config.base_img_url3 + 'map/lby/{z}/{x}/{y}.png';
+	  this.addXYZLayer(xyz2,{minZoom:15,maxZoom:22});
   }
 	addXYZLayer(url,options){
 		let xyz = new XYZLayer(url,options,3);

+ 16 - 3
src/views/home/index.vue

@@ -50,18 +50,31 @@ import homePage from "./components/homePage.vue";
 import weatherPage from "./components/weatherPage.vue";
 import phenologyPage from "./components/phenologyPage.vue";
 import { useRouter } from "vue-router";
+import SamplePointLayer from "./samplePointLayer";
+import {useStore} from "vuex";
+let store = useStore()
 const components = {
   homePage,
   weatherPage,
   phenologyPage,
 };
-
+//当前农场
+const currentFarm = {
+  id: store.getters.userinfo.curFarmId,
+  name: store.getters.userinfo.curFarmName,
+}
+//当前区域
+const currentRegion = {
+  id: null,
+  name: null
+}
 let homeMap = new HomeMap();
+let samplePointLayer = null
 const router = useRouter();
 const mapRef = ref();
 onMounted(() => {
-  let location = "POINT (113.78049350268851 23.419886891845312)";
-  homeMap.initMap(location, mapRef.value);
+  homeMap.initMap(store.getters.userinfo.location, mapRef.value);
+  samplePointLayer = new SamplePointLayer(homeMap.kmap.map, currentFarm, currentRegion)
 });
 
 const currentComponent = ref("homePage");

+ 76 - 0
src/views/home/regionLayer.js

@@ -0,0 +1,76 @@
+import config from "@/api/config.js";
+import * as KMap from "@/utils/ol-map/KMap";
+import * as util from "@/common/ol_common.js";
+import Point from "ol/geom/Point.js";
+import Feature from "ol/Feature";
+import VectorLayer from "ol/layer/Vector.js";
+import WKT from "ol/format/WKT.js";
+import ScaleLine from "ol/control/ScaleLine";
+import { useRouter } from "vue-router";
+import {unByKey} from "ol/Observable";
+import Style from "ol/style/Style";
+import Icon from "ol/style/Icon";
+import {Cluster, Vector as VectorSource} from "ol/source";
+import {newRegionFeature} from "../zhgl/map";
+
+/**
+ * @description 地图层对象
+ */
+class SamplePointLayer {
+  constructor(map, farm) {
+    let that = this;
+    this.farmId = farm.id
+    let vectorStyle = new KMap.VectorStyle();
+    this.vectorStyle = vectorStyle;
+
+    this.regionLayer = new KMap.VectorLayer("regionLayer",999,{
+      minZoom:15,
+      source:this.clusterSource,
+      style:(f)=> this.getStyle(f)})
+    map.addLayer(this.regionLayer.layer)
+    this.initData(this.farmId)
+  }
+  getIconStyle(feature){
+    let style = new Style({
+      image: new Icon({
+        src: feature.get('icon'),
+        scale:1,
+      })
+    });
+    return style
+  }
+  //得到点样式
+  getStyle(feature){
+    return this.getIconStyle(feature)
+  }
+
+  initData(farmId){
+    let that = this
+    VE_API.sample.list({farmId}).then(({data})=>{
+      let features = []
+      for(let item of data){
+        that.getIcon(item)
+        let f = newRegionFeature(item);
+        features.push(f)
+      }
+      const source = new VectorSource({
+        features: features,
+      });
+      that.regionLayer.setSource(source)
+    })
+  }
+
+  reset(farm, region){
+    this.clearCluster()
+    this.initData(farm.id, region.id)
+  }
+
+  // 清除聚合图层,解除绑定
+  clearCluster() {
+    if (this.regionLayer) {
+      this.regionLayer.layer.getSource().clear()
+    }
+  }
+}
+
+export default SamplePointLayer;

+ 107 - 0
src/views/home/samplePointLayer.js

@@ -0,0 +1,107 @@
+import config from "@/api/config.js";
+import * as KMap from "@/utils/ol-map/KMap";
+import * as util from "@/common/ol_common.js";
+import Point from "ol/geom/Point.js";
+import Feature from "ol/Feature";
+import VectorLayer from "ol/layer/Vector.js";
+import WKT from "ol/format/WKT.js";
+import ScaleLine from "ol/control/ScaleLine";
+import { useRouter } from "vue-router";
+import {unByKey} from "ol/Observable";
+import Style from "ol/style/Style";
+import Icon from "ol/style/Icon";
+import {Cluster, Vector as VectorSource} from "ol/source";
+import {newPoint} from "../zhgl/map";
+
+/**
+ * @description 地图层对象
+ */
+class SamplePointLayer {
+  constructor(map, farm, region) {
+    let that = this;
+    this.farmId = farm.id
+    this.regionId = region.id
+    let vectorStyle = new KMap.VectorStyle();
+    this.vectorStyle = vectorStyle;
+    this.clusterSource = new Cluster({
+      distance: 15,
+      minDistance: 60,
+    });
+
+    this.treeClusterLayer = new KMap.VectorLayer("tree-cluster",999,{
+      minZoom:15,
+      source:this.clusterSource,
+      style:(f)=> this.getStyle(f)})
+    map.addLayer(this.treeClusterLayer.layer)
+    this.initData(this.farmId, this.regionId)
+  }
+  getIconStyle(feature){
+    let style = new Style({
+      image: new Icon({
+        src: feature.get('icon'),
+        scale:1,
+      })
+    });
+    return style
+  }
+  //多点的过滤方法
+  manyFeatureFilter(features){
+    let res = features[0]
+    if(features.length == 1){
+      return res
+    }
+    for(let item of features){
+      res = res.get('status') > item.get('status') ? res : item
+    }
+    return res;
+  }
+  //得到点样式
+  getStyle(feature){
+    feature = this.manyFeatureFilter(feature.get('features'))
+    return this.getIconStyle(feature)
+  }
+
+  initData(farmId, regionId){
+    let that = this
+    VE_API.sample.list({farmId,regionId}).then(({data})=>{
+      let features = []
+      for(let item of data){
+        that.getIcon(item)
+        let point = newPoint(item);
+        features.push(point)
+      }
+      const source = new VectorSource({
+        features: features,
+      });
+      that.clusterSource.setSource(source)
+    })
+  }
+
+  getIcon(item){
+    let imgSrc = require('@/assets/status/status_xfdw.png')
+    if(item.status == 1){
+      imgSrc = require('@/assets/status/status_dfh.png')
+    }
+    if(item.status == 2){
+      imgSrc = require('@/assets/status/status_szyc.png')
+    }
+    if(item.status == 3){
+      imgSrc = require('@/assets/status/status_bcyc.png')
+    }
+    item["icon"] = imgSrc
+  }
+
+  reset(farm, region){
+    this.clearCluster()
+    this.initData(farm.id, region.id)
+  }
+
+  // 清除聚合图层,解除绑定
+  clearCluster() {
+    if (this.treeClusterLayer) {
+      this.treeClusterLayer.layer.getSource().getSource().clear()
+    }
+  }
+}
+
+export default SamplePointLayer;

+ 1 - 1
src/views/zhgl/map.js

@@ -91,7 +91,7 @@ export const newRegionFeature = (data)=>{
 
 
 export const newPoint = (data)=>{
-    let point = new WKT().readGeometry(data["wkt"])
+    let point = new WKT().readGeometry(data["wkt"] || data["point"])
     let feature = new Feature({
         geometry: point
     });

文件差异内容过多而无法显示
+ 195 - 428
yarn.lock


部分文件因为文件数量过多而无法显示