|
@ -4,93 +4,94 @@ import request from 'superagent' |
|
|
import { OlMapRequest } from '$utils' |
|
|
import { OlMapRequest } from '$utils' |
|
|
|
|
|
|
|
|
const OlMap = (props) => { |
|
|
const OlMap = (props) => { |
|
|
const { dispatch, actions, user } = props |
|
|
const { dispatch, actions, user, olMapArcgisHost, olMapGeoDataHost } = props |
|
|
const [olMapOpenData, setOlMapOpenData] = useState([]) |
|
|
const [olMapOpenData, setOlMapOpenData] = useState([]) |
|
|
useEffect(() => { |
|
|
useEffect(() => { |
|
|
let config = { |
|
|
|
|
|
layerName: 'nanchang', |
|
|
|
|
|
center: [116.08706, 28.602018], // 中心坐标
|
|
|
|
|
|
zoom: 10, // 缩放
|
|
|
|
|
|
minZoom: 8, |
|
|
|
|
|
maxZoom: 21, |
|
|
|
|
|
isMoveSelect: false, // 鼠标滑过是否选中
|
|
|
|
|
|
projection: 'EPSG:4326' // 坐标系
|
|
|
|
|
|
} |
|
|
|
|
|
let arcgisUrls = { |
|
|
|
|
|
nanchang: { |
|
|
|
|
|
url: 'http://36.2.6.33:6080/arcgis/rest/services/PBDT/nachang/MapServer', |
|
|
|
|
|
}, |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}, []) |
|
|
|
|
|
|
|
|
|
|
|
useEffect(() => { |
|
|
|
|
|
console.log(olMapGeoDataHost); |
|
|
|
|
|
if (olMapGeoDataHost) { |
|
|
|
|
|
let config = { |
|
|
|
|
|
layerName: 'nanchang', |
|
|
|
|
|
center: [116.08706, 28.602018], // 中心坐标
|
|
|
|
|
|
zoom: 10, // 缩放
|
|
|
|
|
|
minZoom: 8, |
|
|
|
|
|
maxZoom: 21, |
|
|
|
|
|
isMoveSelect: false, // 鼠标滑过是否选中
|
|
|
|
|
|
projection: 'EPSG:4326' // 坐标系
|
|
|
|
|
|
} |
|
|
|
|
|
let arcgisUrls = { |
|
|
|
|
|
nanchang: { |
|
|
|
|
|
url: `${olMapArcgisHost || 'http://36.2.6.33:6080'}/arcgis/rest/services/PBDT/nachang/MapServer`, |
|
|
|
|
|
}, |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
let option = { |
|
|
let option = { |
|
|
target: 'olMap', // 元素ID
|
|
|
target: 'olMap', // 元素ID
|
|
|
config: config, |
|
|
config: config, |
|
|
arcgisUrls, // 动态底图图层
|
|
|
arcgisUrls, // 动态底图图层
|
|
|
onEvent: { |
|
|
onEvent: { |
|
|
// 选中回调
|
|
|
// 选中回调
|
|
|
onSelectClick: function (p) { console.log(p) }, |
|
|
onSelectClick: function (p) { |
|
|
// 鼠标滑过回调
|
|
|
// console.log(p)
|
|
|
onPointerMove: function (p) { console.log(p) }, |
|
|
}, |
|
|
|
|
|
// 鼠标滑过回调
|
|
|
|
|
|
onPointerMove: function (p) { |
|
|
|
|
|
// console.log(p)
|
|
|
|
|
|
}, |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
let olMapTool = new OlMapTool(option) |
|
|
let olMapTool = new OlMapTool(option) |
|
|
olMapTool.map.on('dblclick', function (p) { |
|
|
olMapTool.map.on('dblclick', function (p) { |
|
|
// console.log(p)
|
|
|
console.log(p) |
|
|
}) |
|
|
}) |
|
|
olMapTool.map.on('singleclick', function (p) { |
|
|
olMapTool.map.on('singleclick', function (p) { |
|
|
|
|
|
console.log("singleclick", p) |
|
|
|
|
|
|
|
|
|
|
|
olMapTool.closeOverlay('clickOpen') |
|
|
olMapTool.closeOverlay('clickOpen') |
|
|
olMapTool.removeGeometryLayer('geometry0') |
|
|
olMapTool.removeGeometryLayer('geometry0') |
|
|
|
|
|
|
|
|
request.post('http://36.2.6.32:8811/geoserver-pg/rest/bufferSearch') |
|
|
request.post(`${olMapGeoDataHost || 'http://36.2.6.32:8811'}/geoserver-pg/rest/bufferSearch`) |
|
|
.type('form') |
|
|
.type('form') |
|
|
.send({ |
|
|
.send({ |
|
|
params: `{"layerName":"view_by_line","pageSize":10,"pageNum":1,"filter":"","isReturnGeometry":"true","spatialRel":"INTERSECTS","orderByFields":" sort1, sort2, lxbm, sxxfx, qdzh asc", "spatialFilter":"point(${p.coordinate[0]} ${p.coordinate[1]})","distance":20}` |
|
|
params: `{"layerName":"view_by_line","pageSize":10,"pageNum":1,"filter":"","isReturnGeometry":"true","spatialRel":"INTERSECTS","orderByFields":" sort1, sort2, lxbm, sxxfx, qdzh asc", "spatialFilter":"point(${p.coordinate[0]} ${p.coordinate[1]})","distance":20}` |
|
|
}) |
|
|
}) |
|
|
.then(res => { |
|
|
.then(res => { |
|
|
console.log(res); |
|
|
if (res.status == 200 && res.body && res.body.code == 1) { |
|
|
if (res.status == 200 && res.body && res.body.code == 1) { |
|
|
const data = res.body.data |
|
|
const data = res.body.data |
|
|
const { datalist } = data |
|
|
const { datalist } = data |
|
|
let index = 0 |
|
|
let index = 0 |
|
|
for (let d of datalist.list) { |
|
|
for (let d of datalist.list) { |
|
|
olMapTool.addGeometryJMLayer({ |
|
|
olMapTool.addGeometryJMLayer({ |
|
|
features: [ |
|
|
features: [ |
|
|
{ |
|
|
{ |
|
|
geometry: d.shape, |
|
|
geometry: d.shape, |
|
|
geometryType: 'LineString', |
|
|
geometryType: 'LineString', |
|
|
// geometryType: 'Point',
|
|
|
// geometryType: 'Point',
|
|
|
}, |
|
|
}, |
|
|
], |
|
|
], |
|
|
style: { stroke: { width: 10, color: '#9933FF' } }, |
|
|
style: { stroke: { width: 10, color: '#9933FF' } }, |
|
|
selectStyle: { stroke: { width: 5, color: '#9933FF' } }, |
|
|
selectStyle: { stroke: { width: 5, color: '#9933FF' } }, |
|
|
layerName: 'geometry' + index++ |
|
|
layerName: 'geometry' + index++ |
|
|
}); |
|
|
}); |
|
|
const config = { |
|
|
const config = { |
|
|
id: 'clickOpen', |
|
|
id: 'clickOpen', |
|
|
offset: [0, 25], // 偏移
|
|
|
offset: [0, 25], // 偏移
|
|
|
position: p.coordinate, // 坐标
|
|
|
position: p.coordinate, // 坐标
|
|
|
autoPan: true, |
|
|
autoPan: true, |
|
|
autoPanMargin: 100, |
|
|
autoPanMargin: 100, |
|
|
positioning: 'top-right' |
|
|
positioning: 'top-right' |
|
|
} |
|
|
|
|
|
setOlMapOpenData([{ k: Math.random() }]) |
|
|
|
|
|
olMapTool.addOverlay('clickOpen', config) |
|
|
|
|
|
break |
|
|
} |
|
|
} |
|
|
setOlMapOpenData([{ k: Math.random() }]) |
|
|
|
|
|
olMapTool.addOverlay('clickOpen', config) |
|
|
|
|
|
break |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
}) |
|
|
}) |
|
|
}) |
|
|
|
|
|
} |
|
|
}) |
|
|
}, [olMapGeoDataHost]) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}, []) |
|
|
|
|
|
|
|
|
|
|
|
return ( |
|
|
return ( |
|
|
<div id="olMap" style={{ position: 'absolute', height: '100%', width: "100%" }}> |
|
|
<div id="olMap" style={{ position: 'absolute', height: '100%', width: "100%" }}> |
|
@ -109,8 +110,8 @@ const OlMap = (props) => { |
|
|
{ |
|
|
{ |
|
|
olMapOpenData.map(s => { |
|
|
olMapOpenData.map(s => { |
|
|
return <div style={{ display: 'flex' }}> |
|
|
return <div style={{ display: 'flex' }}> |
|
|
<div style={{ width: 120 }}>1</div> |
|
|
{/* <div style={{ width: 120 }}>1</div> |
|
|
<div style={{ flex: 1 }}>: {s.k}</div> |
|
|
<div style={{ flex: 1 }}>: {s.k}</div> */} |
|
|
</div> |
|
|
</div> |
|
|
}) |
|
|
}) |
|
|
} |
|
|
} |
|
@ -125,6 +126,8 @@ function mapStateToProps (state) { |
|
|
return { |
|
|
return { |
|
|
user: auth.user, |
|
|
user: auth.user, |
|
|
actions: global.actions, |
|
|
actions: global.actions, |
|
|
|
|
|
olMapArcgisHost: global.olMapArcgisHost, |
|
|
|
|
|
olMapGeoDataHost: global.olMapGeoDataHost, |
|
|
}; |
|
|
}; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|