<!DOCTYPE html> <html> <head> <meta charset="utf-8"/> <title>hello-jsmap</title> <script src="http://192.168.192.201:7024/joysuch/jsmap/jsmap.js" type="text/javascript"></script> <link type="text/css" href="http://192.168.192.201:7024/joysuch/jsmap/jsmap.css" rel="stylesheet"/> <!-- <script src="http://mapdemo.joysuch.com/lib/jsmap/jsmap.js" type="text/javascript"></script>--> <!-- <link type="text/css" href="http://mapdemo.joysuch.com/lib/jsmap/jsmap.css" rel="stylesheet"/>--> <link rel="stylesheet" href="http://192.168.192.201:7024/joysuch/LocalAssets/css/animation/pop.css"> <link rel="stylesheet" href="http://192.168.192.201:7024/joysuch/LocalAssets/css/animation/loading.css"> <link rel="stylesheet" href="http://192.168.192.201:7024/joysuch/LocalAssets/css/dom.css"> <style> .jsmap-animation-point, .jsmap-animation-point:after, .jsmap-animation-point:before, .jsmap-animation-point p, .jsmap-animation-point p:after, .jsmap-animation-point p:before { margin: 0; padding: 0; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -o-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; } .jsmap-animation-point { width: 10px; height: 10px; border-radius: 50%; border: 1px solid hsla(0, 0%, 100%, 0.5); cursor: pointer; color: #0ff; background: currentColor; z-index: 3; left: 50%; top: 50%; -webkit-transform: translate(-50%, -50%); -moz-transform: translate(-50%, -50%); -o-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); transform: translate(-50%, -50%); box-shadow: 0 0 2em currentColor, 0 0 0.5em currentColor; position: absolute; } .jsmap-animation-point:after, .jsmap-animation-point:before, .jsmap-animation-point p:after, .jsmap-animation-point p:before { content: ""; position: absolute; width: 100%; height: 100%; left: 50%; top: 50%; border-radius: 50%; -webkit-transform: translate(-50%, -50%); -moz-transform: translate(-50%, -50%); -o-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); transform: translate(-50%, -50%); } .jsmap-animation-point:after, .jsmap-animation-point:before { border: 1px solid; -webkit-animation: jsmap-mapAni 1s ease infinite; -moz-animation: jsmap-mapAni 1s ease infinite; -o-animation: jsmap-mapAni 1s ease infinite; -ms-animation: jsmap-mapAni 1s ease infinite; animation: jsmap-mapAni 1s ease infinite; } .jsmap-animation-point p:before { border: 1px solid; } .jsmap-animation-point p { position: absolute; left: 50%; top: 50%; width: 0; height: 0; border-radius: 50%; -webkit-transform: translate(-50%, -50%); -moz-transform: translate(-50%, -50%); -o-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); transform: translate(-50%, -50%); -webkit-animation: jsmap-mapAni 2s ease infinite; -moz-animation: jsmap-mapAni 2s ease infinite; -o-animation: jsmap-mapAni 2s ease infinite; -ms-animation: jsmap-mapAni 2s ease infinite; animation: jsmap-mapAni 2s ease infinite; } @-webkit-keyframes jsmap-mapAni { 0% { width: 0; height: 0; opacity: 1; filter: alpha(opacity=1); } 25% { width: 12px; height: 12px; opacity: 0.7; filter: alpha(opacity=70); } 50% { width: 20px; height: 20px; opacity: 0.5; filter: alpha(opacity=50); } 75% { width: 30px; height: 30px; opacity: 0.2; filter: alpha(opacity=20); } to { width: 40px; height: 40px; opacity: 0; filter: alpha(opacity=0); } } @-moz-keyframes jsmap-mapAni { 0% { width: 0; height: 0; opacity: 1; filter: alpha(opacity=1); } 25% { width: 12px; height: 12px; opacity: 0.7; filter: alpha(opacity=70); } 50% { width: 20px; height: 20px; opacity: 0.5; filter: alpha(opacity=50); } 75% { width: 30px; height: 30px; opacity: 0.2; filter: alpha(opacity=20); } to { width: 40px; height: 40px; opacity: 0; filter: alpha(opacity=0); } } @-o-keyframes jsmap-mapAni { 0% { width: 0; height: 0; opacity: 1; filter: alpha(opacity=1); } 25% { width: 12px; height: 12px; opacity: 0.7; filter: alpha(opacity=70); } 50% { width: 20px; height: 20px; opacity: 0.5; filter: alpha(opacity=50); } 75% { width: 30px; height: 30px; opacity: 0.2; filter: alpha(opacity=20); } to { width: 40px; height: 40px; opacity: 0; filter: alpha(opacity=0); } } @-ms-keyframes jsmap-mapAni { 0% { width: 0; height: 0; opacity: 1; filter: alpha(opacity=1); } 25% { width: 12px; height: 12px; opacity: 0.7; filter: alpha(opacity=70); } 50% { width: 20px; height: 20px; opacity: 0.5; filter: alpha(opacity=50); } 75% { width: 30px; height: 30px; opacity: 0.2; filter: alpha(opacity=20); } to { width: 40px; height: 40px; opacity: 0; filter: alpha(opacity=0); } } @keyframes jsmap-mapAni { 0% { width: 0; height: 0; opacity: 1; filter: alpha(opacity=1); } 25% { width: 12px; height: 12px; opacity: 0.7; filter: alpha(opacity=70); } 50% { width: 20px; height: 20px; opacity: 0.5; filter: alpha(opacity=50); } 75% { width: 30px; height: 30px; opacity: 0.2; filter: alpha(opacity=20); } to { width: 40px; height: 40px; opacity: 0; filter: alpha(opacity=0); } } </style> </head> <body> <div id='mapContainer'></div> <script type="text/javascript"> //定义全局map变量 var map = null; //定义地图ID变量 var mapID = '100930'; //定义循环的起始变量 var i = 0; //创建存储标注的数组 var markerArr = []; var markerIDArr = []; //记录当前所选的Marker var currentMarker = null; //定义点标注全局变量 var circleMarker = null; //空间查询对象 var spatialQuery = null; window.onload = function () { window.addEventListener('message', function (e) { //加载地图 // console.info('地图加载完成') // console.info(mapData) openMap(e.data); add(e.data); // addBox(e.data); addWall(e.data); }); }; window.addEventListener('unload', function (e) { //销毁地图 map.destroy(); map = null; }); //打开地图 function openMap(mapData) { //初始化参数 var mapOptions = { //必要,地图容器 container: 'mapContainer', //必要,地图类型 mapType: jsmap.JSMapType.MAP_3D, //必要,地图路径 // mapServerURL: 'http://mapdemo.joysuch.com', mapServerURL: 'http://192.168.192.201:7024/joysuch/jsmap/data/map', mapScaleLevelRange: [15,20], //地图缩放范围,默认[1,24] openingAnimation: false, enableLighting: true, enableShadows: true, viewOptions: { center: { x: mapData.LONGITUDE, y: mapData.LATITUDE, z: 0 }, distance: mapData.distance, rotate: mapData.rotate, tilt: mapData.tilt }, imageryProvider: jsmap.JSImageryProviderType.IMAGE_TDT, }; //初始化地图对象 map = new jsmap.JSMap(mapOptions); //打开map服务器的地图数据和主题 map.openMapById(mapID); //地图加载完成事件 map.on("loadComplete", e => { var compassControl = new jsmap.JSCompassControl({ position: jsmap.JSControlPosition.LEFT_TOP, offset: { x: 10, y: 20 } }); var zoomControl = new jsmap.JSZoomControl({ position: jsmap.JSControlPosition.LEFT_TOP, offset: { x: 40, y: 10 } }); if (document.documentElement.clientWidth >= 600) { map.addControl(compassControl); map.addControl(zoomControl); } }); spatialQuery = new jsmap.JSSpatialQuery(map); map.on('mapClickNode', event => { console.info(event) if(event.properties){ window.parent.postMessage(event.properties,'*') } }); map.on('mapRightClickNode', function(event) { if (validStr(event.properties) && event.properties.get('type') === 'majordangersource') { if (validStr(circleMarker)) { map.removeAllCircleMarker(); } map.highlightMarker([]); circleMarker = new jsmap.JSCircleMarker({ id: 'circleMarker', position: new jsmap.JSPoint(event.x, event.y, 0), floorId: 0, color: 'rgba(0,255,255,0.3)', radius: 100, clampToGround: true, circleType: jsmap.JSCircleType.FILL, depthTest: false, show: true, allowPicking: false, displayCondition: new jsmap.JSDisplayCondition(0.0, 1000), properties: { test: 'circleMarker' }, callback: (marker) => { console.log(marker); } }); map.addMarker(circleMarker); let circle = new jsmap.JSCircle({x:event.x,y:event.y,z:2},100); var result = spatialQuery.query({ geometry: circle, spatialQueryMode:jsmap.JSSpatialQueryMode.CONTAIN,//定义空间查询模式:包含关系 markerType:[jsmap.JSMarkerType.ICON_TEXT_MARKER],//查询标注类型 propertiesFilter: (properties) => {//属性过滤条件 return properties && properties.get('type') === 'video'; }, }); console.log('result',result); for (let j = 0; j < result.length; j++) { map.highlightMarker(result[j]); } } // console.log('mapRightClickNode', event); // event.FID: 点击的nodeID // event.centroid: 点击的node的质心 // event.eventInfo:{coord: 地图坐标, eventID:event事件ID} // event.floorId:点击楼层ID // event.mapCoord:地图坐标 // event.node:点击的node // event.nodeType:node的类型,见JSNodeType枚举 // event.properties:node的属性信息 // event.x:地图坐标x // event.y:地图坐标y }); } function validStr(str) { if (str != null && str != '' && typeof (str) != 'undefined' && str != 'undefined' && str != 0) { return true } return false } //添加标注 function add(data) { for (let j = 0; j < data.varList.length; j++) { let mapData = data.varList[j]; if (!(validStr(mapData.LONGITUDE) && validStr(mapData.LONGITUDE))){ continue } markerIDArr.push(mapData.id) let iconTextMarker = new jsmap.JSIconTextMarker({ id: j, position: { x: Number(mapData.LONGITUDE), y: Number(mapData.LATITUDE), z: 2 }, //坐标 floorId: 1, //楼层id,默认为1(地面) image: mapData.IMAGE_FILE, imageHeight: validStr(data.imageHeight) ? data.imageHeight : 35, //图片高度 imageWidth: validStr(data.imageWidth) ? data.imageWidth : 35, //图片宽度 offset: jsmap.JSControlPosition.RIGHT_BOTTOM, text: mapData.NAME,//文字 font: 'bold 12px 微软雅黑',//字体 fontColor: '#ff7744',//文字颜色 fontStrokeColor: '#77ddff', //字体描边颜色 fontStrokeWidth: 1, //字体描边宽度 backgroundColor: '#409EFF', //背景色颜色 backgroundRadius: 1, // 背景圆角 backgroundStrokeColor: '#CD5C5C', //背景边线颜色 backgroundStrokeWidth: 1, //背景边线宽度 iconTextType: jsmap.JSIconTextType.TOPTEXT_BOTTOMICON, depthTest: false,//是否开启深度检测 properties: { id: mapData.id, type: mapData.TYPE }, //属性设置 callback: (node) => { // console.log(node); } //回调事件 }); map.addMarker(iconTextMarker); markerArr.push(iconTextMarker); } console.log('markerArr',markerArr) console.log('markerIDArr',markerIDArr) } //添加标注 function addBox(data) { for (let j = 0; j < data.boxList.length; j++) { let mapData = data.boxList[j]; let boxMarker = new jsmap.JSBoxMarker({ id: j, position: mapData.position, //坐标 floorId: 1, //楼层id,默认为1(地面) color: mapData.color, //颜色 height: 0, //基底高度 stretchHeight: mapData.stretchHeight, //拉伸高度 strokeColor: mapData.strokeColor, //边线颜色 strokeWidth: 4, //边线宽度 // properties: { // id: mapData.id // }, //属性设置 callback: (node) => { // console.log(node); } //回调事件 }); map.addMarker(boxMarker); markerArr.push(boxMarker) } } //添加标注 function addWall(data) { let mapData = data.wallMap; let wallMarker = new jsmap.JSWallMarker({ id: 'wallMarker', position: mapData.position, //坐标 floorId: 1, //楼层id,默认为1(地面) color: 'rgb(139,71,137)', //颜色 closed: true, //墙是否闭合 baseHeight: 0, //基底高度 height: 20, //高度 wallType: jsmap.JSWallType.WAVE, //墙类型 callback: (node) => { // console.log(node); } //回调事件 }); map.addMarker(wallMarker); markerArr.push(wallMarker) } function showCurrentMarker(id){ // console.info("我是html页面的方法,传给我的Id:" + id) currentMarker = markerArr.find( item => item._id === id); if(currentMarker !== undefined){ map.flyToMarker(currentMarker); } } </script> </body> </html>