From 082613d446e29e4ec1c16bfaa52345106a498b23 Mon Sep 17 00:00:00 2001
From: guoshilong <123456>
Date: Tue, 08 Nov 2022 09:03:49 +0800
Subject: [PATCH] 农事操作隐藏后四个,地图模式2d改为3d
---
src/components/map/plotMap.vue | 239 ++++++++++++++++++++++++++++++++++++++++-------------------
1 files changed, 162 insertions(+), 77 deletions(-)
diff --git a/src/components/map/plotMap.vue b/src/components/map/plotMap.vue
index a99cec7..d2134de 100644
--- a/src/components/map/plotMap.vue
+++ b/src/components/map/plotMap.vue
@@ -5,10 +5,16 @@
</template>
<script>
+import NCregion from "@/assets/region"
+import { glob } from "glob"
+import {getDetail } from "@/api/farm/farm"
+import { mapGetters } from "vuex"
+import * as turf from '@turf/turf'
var farmRegionLayer = null
var plotRegionLayer = null
var farmLogoLayer = null
+var regionPolyLineLayer = null
var addLayers = []
var addPlotLayers = []
@@ -18,24 +24,25 @@
data () {
return {
polyline: null,
+ farm:{},
}
},
watch: {
'polyline' (newObj, oldObj) {
if (newObj && oldObj) {
- plotRegionLayer.removeOverlay(oldObj)
+ plotRegionLayer.removeOverlay(oldObj)
}
}
},
computed: {
-
+ ...mapGetters(["$farmId"]),
},
mounted () {
if (global.viewer != null) {
global.viewer = null
}
- function initViewer () {
+ function initViewer (lat,lon) {
global.viewer = new global.DC.Viewer('viewer-container', {
contextOptions: {
webgl: {
@@ -44,7 +51,6 @@
preserveDrawingBuffer: true
}
},
- sceneMode: 2
})
farmRegionLayer = new global.DC.VectorLayer('farmRegionLayer')
@@ -55,6 +61,9 @@
farmLogoLayer = new global.DC.HtmlLayer('farmLogoLayer')
global.viewer.addLayer(farmLogoLayer)
+ // 南城县边界数据
+ regionPolyLineLayer = new global.DC.VectorLayer('regionPolyLineLayer')
+ global.viewer.addLayer(regionPolyLineLayer)
if (global.DC.Namespace.Cesium.FeatureDetection.supportsImageRenderingPixelated()) { // 判断是否支持图像渲染像素化处理
global.viewer.setOptions({
@@ -203,12 +212,11 @@
// maximumLevel: 18
// })
// )
-
global.viewer.camera.setView({
// Cesium的坐标是以地心为原点,一向指向南美洲,一向指向亚洲,一向指向北极州
// fromDegrees()方法,将经纬度和高程转换为世界坐标
destination: global.DC.Namespace.Cesium.Cartesian3.fromDegrees(
- 116.56705776, 27.42386903, 1800.0
+ lon, lat, 1800.0
),
orientation: {
// 指向
@@ -222,9 +230,43 @@
// global.viewer.locationBar.enable = true
}
- global.DC.ready(initViewer)
+ getDetail(this.$farmId).then(res=>{
+ this.farm.latitude = res.data.data.latitude
+ this.farm.longitude = res.data.data.longitude
+ // global.DC.ready(initViewer(this.farm.latitude,this.farm.longitude))
+
+ global.DC.ready(() => {
+ initViewer(this.farm.latitude,this.farm.longitude)
+ })
+
+ this.addRegionPolyLine(NCregion)
+ })
},
methods: {
+ /**
+ * 添加南城县边界的数据
+ * @param {string} url arcgis服务地址
+ */
+ addRegionPolyLine (regionJSON) {
+ let position = ''
+
+ regionJSON.features[0].geometry.rings[0].forEach(item => {
+ position += `${item[0]}, ${item[1]};`
+ })
+
+ // console.log(position, 565656)
+
+ const polyline = new global.DC.Polyline(position)
+ polyline.setStyle({
+ width: 4,
+ material: global.DC.Namespace.Cesium.Color.fromBytes(
+ 244, 157, 21,
+ 200
+ ),
+ clampToGround: true
+ })
+ regionPolyLineLayer.addOverlay(polyline)
+ },
addPolygon (positions, item) {
const that = this
@@ -260,60 +302,85 @@
addPlotPolygon (positions, item) {
const that = this
const center = this.getCenter(positions)
- if(item.strainUrl !=""){
+ if (item.strainUrl != "") {
const urls = item.strainUrl.split(',')
- let imageStr = `<div class="farm-map-icon">`;
+ let imageStr = `<div class="farm-map-icon">`
+ var i = 0;
+ //billboard image可以添加canvas
+ // const canvas = document.createElement('canvas');
+ // var ctx=c.getContext("2d");
urls.forEach(url => {
- imageStr += `<img src="${url}" alt=""width="100px" height="100px" text-align="center" class="strainImg">`
+ // imageStr += `<img src="${url}" alt=""width="100px" height="100px" text-align="center" class="strainImg">`
+ // imageStr += `<img src="${url}" alt=""width="50%" height="auto" text-align="center" class="strainImg">`
+ global.viewer.entities.add({
+ position: global.DC.Namespace.Cesium.Cartesian3.fromDegrees(center[0]-(i*0.002) + (i*0.00120), center[1]),
+ billboard: {
+ image: url, // default: undefined
+ scaleByDistance: new global.DC.Namespace.Cesium.NearFarScalar(0, 1.5, 50000, 0.3),
+ width:50,
+ height:50,
+ },
+ })
+ i++;
+
})
- imageStr += `</div>`
- const divIcon = new global.DC.DivIcon(
- new global.DC.Position(center[0], center[1], 0),imageStr
- )
-
- divIcon.attrParams = item
- farmLogoLayer.addOverlay(divIcon)
-
-
- // divIcon.on(global.DC.MouseEventType.CLICK, (e) => {
- // that.$parent.showDetailPopup(e.overlay.attrParams)
+ // imageStr += `</div>`
+ // const divIcon = new global.DC.DivIcon(
+ // new global.DC.Position(center[0], center[1], 0), imageStr
+ // )
+ // divIcon.attrParams = item
+ // divIcon.setStyle({
+ // className:"ttttttt",
+ // scaleByDistance:new global.DC.Namespace.Cesium.NearFarScalar(0, 2, 50000, 0.5),
+ // // scaleByDistance:{
+ // // near: 0, //最近距离
+ // // nearValue: 0.8, //最近距离值
+ // // far:17118300, //最远距离值
+ // // farValue: 0.5 //最远距离值
+ // // },
+ // // distanceDisplayCondition:{
+ // // near:0,
+ // // far:17118300
+ // // }
// })
+ // farmLogoLayer.addOverlay(divIcon)
}
- const polygon = new global.DC.Polygon(positions)
- polygon.attrParams = item
- polygon.setStyle({
- material: global.DC.Namespace.Cesium.Color.fromBytes(
- 129, 255, 84,
- 200
- )
- })
+ if(positions){
+ const polygon = new global.DC.Polygon(positions)
+ polygon.attrParams = item
+ polygon.setStyle({
+ material: global.DC.Namespace.Cesium.Color.fromBytes(
+ 129, 255, 84,
+ 200
+ )
+ })
- polygon.on(global.DC.MouseEventType.CLICK, (e) => {
- that.$parent.plotDetailsPopupShow(e.overlay.attrParams)
- that.drawLandPolyLine(positions)
- })
+ polygon.on(global.DC.MouseEventType.CLICK, (e) => {
+ that.$parent.plotDetailsPopupShow(e.overlay.attrParams)
+ that.drawLandPolyLine(positions)
+ })
- console.log(item, 123)
- plotRegionLayer.addOverlay(polygon)
- addPlotLayers.push({ center, name: item.landName, id: item.id })
+ plotRegionLayer.addOverlay(polygon)
+ addPlotLayers.push({ center, name: item.landName, id: item.id })
+ }
},
/**
* 地块画线
* @param positions
*/
drawLandPolyLine (positions) {
- // 画线
- this.polyline = new global.DC.Polyline(positions)
- this.polyline.setStyle({
- width: 4,
- material: global.DC.Namespace.Cesium.Color.fromBytes(
- 200, 255, 255,
- 200
- ),
- clampToGround: true
- })
- plotRegionLayer.addOverlay(this.polyline)
+ // 画线
+ this.polyline = new global.DC.Polyline(positions)
+ this.polyline.setStyle({
+ width: 4,
+ material: global.DC.Namespace.Cesium.Color.fromBytes(
+ 200, 255, 255,
+ 200
+ ),
+ clampToGround: true
+ })
+ plotRegionLayer.addOverlay(this.polyline)
},
/**
* 将数据库保存值转换成Map使用坐标
@@ -328,7 +395,7 @@
const arr = landRange.split(',')
var brr = []
arr.forEach(it => {
- brr.push(it.split(' '))
+ brr.push(it.split(' '))
})
return brr
@@ -363,8 +430,8 @@
setPlotCenter (landObj) {
if (!landObj.landRange) {
this.$message({
- message: '当前地块暂未绘制',
- type: 'warning'
+ message: '当前地块暂未绘制',
+ type: 'warning'
})
return
}
@@ -377,6 +444,7 @@
// 根据坐标画线
const positions = this.setPositionByLandRange(landObj.landRange)
+ console.log(positions,123455555)
if (positions) {
this.drawLandPolyLine(positions)
}
@@ -413,28 +481,45 @@
// 经纬度测算中心位置
getCenter (arr) {
+
+ // if (arr.length) {
+ // const lon = []
+ // const lat = []
+ // const poly = []
+ // for (let i = 0, len = arr.length; i < len; i++) {
+ // lon.push(arr[i][0])
+ // lat.push(arr[i][1])
+ // }
+ // for (let i = 0, len = lon.length; i < len; i++) {
+ // poly.push({
+ // x: parseFloat(lon[i]),
+ // y: parseFloat(lat[i]),
+ // z: 0
+ // })
+ // }
+ // const sortedLongitudeArray = poly.map(item => item.x).sort()
+ // const sortedLatitudeArray = poly.map(item => item.y).sort()
+ // const centerLongitude = ((parseFloat(sortedLongitudeArray[0]) + parseFloat(sortedLongitudeArray[sortedLongitudeArray.length - 1])) / 2).toFixed(14)
+ // const centerLatitude = ((parseFloat(sortedLatitudeArray[0]) + parseFloat(sortedLatitudeArray[sortedLatitudeArray.length - 1])) / 2).toFixed(14)
+ // console.log("经度",centerLongitude, "纬度",centerLatitude)
+ // centerLonLat = [Number(centerLongitude), Number(centerLatitude)]
+ // console.log("中心",centerLonLat)
+ // }
let centerLonLat = []
- if (arr.length) {
- const lon = []
- const lat = []
- const poly = []
- for (let i = 0, len = arr.length; i < len; i++) {
- lon.push(arr[i][0])
- lat.push(arr[i][1])
- }
- for (let i = 0, len = lon.length; i < len; i++) {
- poly.push({
- x: parseFloat(lon[i]),
- y: parseFloat(lat[i]),
- z: 0
- })
- }
- const sortedLongitudeArray = poly.map(item => item.x).sort()
- const sortedLatitudeArray = poly.map(item => item.y).sort()
- const centerLongitude = ((parseFloat(sortedLongitudeArray[0]) + parseFloat(sortedLongitudeArray[sortedLongitudeArray.length - 1])) / 2).toFixed(14)
- const centerLatitude = ((parseFloat(sortedLatitudeArray[0]) + parseFloat(sortedLatitudeArray[sortedLatitudeArray.length - 1])) / 2).toFixed(14)
- console.log(centerLongitude, centerLatitude)
- centerLonLat = [Number(centerLongitude), Number(centerLatitude)]
+ if(arr.length >= 3 ){
+ var positionArr = []
+ arr.forEach(e=>{
+ // e = new global.DC.Namespace.Cesium.Cartesian3(e[0]-0, e[1]-0, 0)
+ e[0] = e[0]-0
+ e[1] = e[1]-0
+ positionArr.push(e)
+ })
+ positionArr.push(arr[0])
+ var positionTurf = [positionArr]
+ var polygon = turf.polygon(positionTurf);
+ var centroid = turf.centroid(polygon);
+
+ centerLonLat = [centroid.geometry.coordinates[0],centroid.geometry.coordinates[1]]
}
return centerLonLat
}
@@ -454,12 +539,12 @@
z-index: 99;
overflow: hidden;
}
-.div-icon{
- background-color: transparent !important;
+.div-icon {
+ background-color: transparent !important;
}
-.strainImg{
- width: 80px;
- height: 80px;
- border-radius:50%;
+.strainImg {
+ width: 80px;
+ height: 80px;
+ border-radius: 50%;
}
</style>
--
Gitblit v1.9.3