ww664853070 2 years ago
parent
commit
cdd1733c60
  1. 2
      web/client/src/layout/actions/global.js
  2. 4
      web/client/src/layout/reducers/global.js
  3. 161
      web/client/src/sections/quanju/containers/public/olMap.js
  4. 7
      web/config.js
  5. 4
      web/routes/attachment/index.js

2
web/client/src/layout/actions/global.js

@ -38,6 +38,8 @@ export function initApiRoot () {
apiRoot: res.root, apiRoot: res.root,
vcmpWebUrl: res.vcmpWebUrl, vcmpWebUrl: res.vcmpWebUrl,
vcmpMirrorId: res.vcmpMirrorId, vcmpMirrorId: res.vcmpMirrorId,
olMapArcgisHost: res.olMapArcgisHost,
olMapGeoDataHost: res.olMapGeoDataHost,
} }
}) })
}); });

4
web/client/src/layout/reducers/global.js

@ -13,6 +13,8 @@ function global (state = {
apiRoot: '', apiRoot: '',
vcmpWebUrl: '', vcmpWebUrl: '',
vcmpMirrorId: '', vcmpMirrorId: '',
olMapArcgisHost: '',
olMapGeoDataHost: ''
}, action) { }, action) {
const payload = action.payload; const payload = action.payload;
switch (action.type) { switch (action.type) {
@ -42,6 +44,8 @@ function global (state = {
apiRoot: payload.apiRoot, apiRoot: payload.apiRoot,
vcmpWebUrl: payload.vcmpWebUrl, vcmpWebUrl: payload.vcmpWebUrl,
vcmpMirrorId: payload.vcmpMirrorId, vcmpMirrorId: payload.vcmpMirrorId,
olMapArcgisHost: payload.olMapArcgisHost,
olMapGeoDataHost: payload.olMapGeoDataHost,
}).toJS(); }).toJS();
default: default:
return state; return state;

161
web/client/src/sections/quanju/containers/public/olMap.js

@ -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,
}; };
} }

7
web/config.js

@ -20,6 +20,8 @@ args.option(['r', 'report-node'], '报表进程地址');
args.option('qndmn', '七牛'); args.option('qndmn', '七牛');
args.option('vcmpWebUrl', '视频平台web可访问地址'); args.option('vcmpWebUrl', '视频平台web可访问地址');
args.option('vcmpMirrorId', '视频平台镜像服务id') args.option('vcmpMirrorId', '视频平台镜像服务id')
args.option('olMapArcgisHost', '江西公路地图 arcgis 查询地址')
args.option('olMapGeoDataHost', '江西公路地图 geoData 查询地址')
const flags = args.parse(process.argv); const flags = args.parse(process.argv);
@ -29,6 +31,9 @@ const API_URL = process.env.API_URL || flags.apiUrl;
// //
const VCMP_WEB_URL = process.env.VCMP_WEB_URL || flags.vcmpWebUrl; const VCMP_WEB_URL = process.env.VCMP_WEB_URL || flags.vcmpWebUrl;
const VCMP_MIRROR_ID = process.env.VCMP_MIRROR_ID || flags.vcmpMirrorId; const VCMP_MIRROR_ID = process.env.VCMP_MIRROR_ID || flags.vcmpMirrorId;
//
const OL_MAP_ARC_GIS_HOST = process.env.OL_MAP_ARC_GIS_HOST || flags.olMapArcgisHost || 'http://36.2.6.33:6080';
const OL_MAP_GEO_DATA_HOST = process.env.OL_MAP_GEO_DATA_HOST || flags.olMapGeoDataHost || 'http://36.2.6.32:8811';
if ( if (
!FS_UNIAPP_API || !FS_UNIAPP_API ||
@ -68,6 +73,8 @@ const product = {
vcmpWebUrl: VCMP_WEB_URL, vcmpWebUrl: VCMP_WEB_URL,
vcmpMirrorId: VCMP_MIRROR_ID, vcmpMirrorId: VCMP_MIRROR_ID,
staticRoot: './client', staticRoot: './client',
olMapArcgisHost: OL_MAP_ARC_GIS_HOST,
olMapGeoDataHost: OL_MAP_GEO_DATA_HOST
} }
}, { }, {
entry: require('./client').entry,// 静态信息 entry: require('./client').entry,// 静态信息

4
web/routes/attachment/index.js

@ -19,9 +19,9 @@ module.exports = {
entry: function (app, router, opts) { entry: function (app, router, opts) {
const getApiRoot = async function (ctx) { const getApiRoot = async function (ctx) {
try { try {
const { apiUrl, qndmn, vcmpWebUrl, vcmpMirrorId } = opts; const { apiUrl, qndmn, vcmpWebUrl, vcmpMirrorId, olMapArcgisHost, olMapGeoDataHost } = opts;
ctx.status = 200; ctx.status = 200;
ctx.body = { root: apiUrl, qndmn, vcmpWebUrl, vcmpMirrorId }; ctx.body = { root: apiUrl, qndmn, vcmpWebUrl, vcmpMirrorId, olMapArcgisHost, olMapGeoDataHost };
} catch (error) { } catch (error) {
console.error('getApiRoot', error) console.error('getApiRoot', error)
} }

Loading…
Cancel
Save