qa-prevention-gwj-vue/static/mapshowimage.html

555 lines
14 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"/>
<title>hello-jsmap</title>
<script src="http://192.168.0.31:8089/joysuch/jsmap/jsmap.js" type="text/javascript"></script>
<link type="text/css" href="http://192.168.0.31:8089/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.0.31:8089/joysuch/LocalAssets/css/animation/pop.css">
<link rel="stylesheet" href="http://192.168.0.31:8089/joysuch/LocalAssets/css/animation/loading.css">
<link rel="stylesheet" href="http://192.168.0.31:8089/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.0.31:8089/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>