Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gassafety
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
耿迪迪
gassafety
Commits
304d92e7
Commit
304d92e7
authored
Aug 30, 2021
by
纪泽龙
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
优化地图模式的功能以及效果
parent
14c07794
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
59 additions
and
25 deletions
+59
-25
gaodeMap.js
gassafety-web/src/utils/gaodeMap.js
+18
-8
index.vue
gassafety-web/src/views/device/map/index.vue
+30
-14
index.vue
gassafety-web/src/views/enterprise/mapView/index.vue
+11
-3
No files found.
gassafety-web/src/utils/gaodeMap.js
View file @
304d92e7
...
@@ -86,13 +86,14 @@ class gaodeMap {
...
@@ -86,13 +86,14 @@ class gaodeMap {
this
.
myMap
.
on
(
"movestart"
,
()
=>
{
this
.
myMap
.
on
(
"movestart"
,
()
=>
{
// console.log("地图平移");
// console.log("地图平移");
// 抽屉点击的时候让infowindow隐藏
// 抽屉点击的时候让infowindow隐藏
if
(
this
.
leftListClick
)
{
if
(
this
.
leftListClick
)
{
console
.
log
(
"moveStart"
)
this
.
closeInfoWindow
();
this
.
closeInfoWindow
();
}
}
});
});
// 地图开始缩放删除infowindow
// 地图开始缩放删除infowindow
this
.
myMap
.
on
(
"zoomstart"
,
()
=>
{
this
.
myMap
.
on
(
"zoomstart"
,
()
=>
{
// console.log("缩放开始")
this
.
closeInfoWindow
();
this
.
closeInfoWindow
();
});
});
this
.
myMap
.
on
(
"moveend"
,
()
=>
{
this
.
myMap
.
on
(
"moveend"
,
()
=>
{
...
@@ -636,20 +637,28 @@ class gaodeMap {
...
@@ -636,20 +637,28 @@ class gaodeMap {
}
}
polyline
.
infoWindow
.
setOffset
(
new
AMap
.
Pixel
(
X
,
Y
));
polyline
.
infoWindow
.
setOffset
(
new
AMap
.
Pixel
(
X
,
Y
));
// 如果是戍边浮动出现infowindow 就让窗口在固定的位置出现,这样就不显得乱了
// 如果是戍边浮动出现infowindow 就让窗口在固定的位置出现,这样就不显得乱了
if
(
e
.
type
==
"mouseover"
)
{
if
(
e
.
type
==
"mouseover"
)
{
const
{
coordinates
}
=
polyline
.
getExtData
().
lineData
;
const
{
coordinates
}
=
polyline
.
getExtData
().
lineData
;
// 计算出前两个点的中点
// 计算出前两个点的中点
const
arr1
=
eval
(
coordinates
)[
0
];
const
arr1
=
eval
(
coordinates
)[
0
];
const
arr2
=
eval
(
coordinates
)[
1
];
const
arr2
=
eval
(
coordinates
)[
1
];
const
a
=
this
.
centerNum
(
arr1
[
0
],
arr2
[
0
]);
const
a
=
this
.
centerNum
(
arr1
[
0
],
arr2
[
0
]);
const
b
=
this
.
centerNum
(
arr1
[
1
],
arr2
[
1
]);
const
b
=
this
.
centerNum
(
arr1
[
1
],
arr2
[
1
]);
const
a2
=
this
.
centerNum
(
a
,
arr1
[
0
])
const
a2
=
this
.
centerNum
(
a
,
arr1
[
0
]);
const
b2
=
this
.
centerNum
(
b
,
arr1
[
1
])
const
b2
=
this
.
centerNum
(
b
,
arr1
[
1
]);
polyline
.
infoWindow
.
open
(
map
,
[
a2
,
b2
]);
polyline
.
infoWindow
.
open
(
map
,
[
a2
,
b2
]);
}
else
{
}
else
{
console
.
log
(
"windowOpen"
);
// 变成异步,最后执行
polyline
.
infoWindow
.
open
(
map
,
e
.
lnglat
);
polyline
.
infoWindow
.
open
(
map
,
e
.
lnglat
);
// setTimeout(() => {
// console.log(polyline.infoWindow.getIsOpen())
// polyline.infoWindow.open(map, e.lnglat);
// }, 0);
// console.log(polyline.infoWindow.)
}
}
// polyline.infoWindow=infoWindow;
// polyline.infoWindow=infoWindow;
this
.
showInfoWindow
=
polyline
.
infoWindow
;
this
.
showInfoWindow
=
polyline
.
infoWindow
;
...
@@ -662,8 +671,8 @@ class gaodeMap {
...
@@ -662,8 +671,8 @@ class gaodeMap {
item
.
setOptions
({
strokeColor
:
"#2EE7E7"
});
item
.
setOptions
({
strokeColor
:
"#2EE7E7"
});
});
});
}
}
centerNum
(
num1
,
num2
)
{
centerNum
(
num1
,
num2
)
{
return
(
Number
(
num1
)
+
Number
(
num2
)
)
/
2
return
(
Number
(
num1
)
+
Number
(
num2
))
/
2
;
}
}
// 创建一条新的线
// 创建一条新的线
createNewLine
()
{
createNewLine
()
{
...
@@ -697,6 +706,7 @@ class gaodeMap {
...
@@ -697,6 +706,7 @@ class gaodeMap {
}
}
// 新建line增加编辑以及右键菜单
// 新建line增加编辑以及右键菜单
closeInfoWindow
()
{
closeInfoWindow
()
{
this
.
showInfoWindow
&&
this
.
showInfoWindow
.
close
();
this
.
showInfoWindow
&&
this
.
showInfoWindow
.
close
();
this
.
markerInfoWindow
&&
this
.
markerInfoWindow
.
close
();
this
.
markerInfoWindow
&&
this
.
markerInfoWindow
.
close
();
}
}
...
...
gassafety-web/src/views/device/map/index.vue
View file @
304d92e7
...
@@ -101,6 +101,7 @@
...
@@ -101,6 +101,7 @@
ref=
"drawer"
ref=
"drawer"
class=
"drawer"
class=
"drawer"
:class=
"{ back: backFlag, opacity: drawerOpacity }"
:class=
"{ back: backFlag, opacity: drawerOpacity }"
@
click
.
stop=
"drawerdrawer"
>
>
<div
class=
"switch"
@
click=
"backFlag = !backFlag"
>
<div
class=
"switch"
@
click=
"backFlag = !backFlag"
>
<img
v-if=
"!backFlag"
src=
"@/assets/images/l.png"
alt=
""
/>
<img
v-if=
"!backFlag"
src=
"@/assets/images/l.png"
alt=
""
/>
...
@@ -324,7 +325,10 @@ export default {
...
@@ -324,7 +325,10 @@ export default {
// 左边的Bar修改值
// 左边的Bar修改值
leftBarChange
(
item
)
{
leftBarChange
(
item
)
{
// this.leftBarNum= this.leftBarNum != item.value ? item.value:0;
// this.leftBarNum= this.leftBarNum != item.value ? item.value:0;
// 关闭infowindow
this
.
gaoMap
.
closeInfoWindow
();
// 恢复颜色
this
.
gaoMap
.
polyLinesColorClear
();
const
index
=
this
.
leftBarNum
.
indexOf
(
item
.
value
);
const
index
=
this
.
leftBarNum
.
indexOf
(
item
.
value
);
if
(
index
>=
0
)
{
if
(
index
>=
0
)
{
this
.
leftBarNum
.
splice
(
index
,
1
);
this
.
leftBarNum
.
splice
(
index
,
1
);
...
@@ -563,7 +567,7 @@ export default {
...
@@ -563,7 +567,7 @@ export default {
this
.
gaoMap
.
closeInfoWindow
();
this
.
gaoMap
.
closeInfoWindow
();
}
}
// 如果没有选择的时候点window 则高亮消失
// 如果没有选择的时候点window 则高亮消失
console
.
log
(
this
.
targetNum
)
console
.
log
(
this
.
targetNum
)
;
if
(
this
.
targetNum
==
1
&&
this
.
iconClass
==
"icon-create"
)
{
if
(
this
.
targetNum
==
1
&&
this
.
iconClass
==
"icon-create"
)
{
this
.
targetNum
=
0
;
this
.
targetNum
=
0
;
}
}
...
@@ -588,9 +592,18 @@ export default {
...
@@ -588,9 +592,18 @@ export default {
});
});
this
.
initMap
();
this
.
initMap
();
},
},
drawerdrawer
()
{
// 关闭infowindow
this
.
gaoMap
.
closeInfoWindow
();
// 恢复颜色
this
.
gaoMap
.
polyLinesColorClear
();
},
// 向右的箭头的动画
// 向右的箭头的动画
arrowRightChange
(
item
)
{
arrowRightChange
(
item
)
{
// 关闭infowindow
this
.
gaoMap
.
closeInfoWindow
();
// 恢复颜色
this
.
gaoMap
.
polyLinesColorClear
();
const
index
=
this
.
arrowRightNum
.
indexOf
(
item
.
value
);
const
index
=
this
.
arrowRightNum
.
indexOf
(
item
.
value
);
if
(
index
>=
0
)
{
if
(
index
>=
0
)
{
this
.
arrowRightNum
.
splice
(
index
,
1
);
this
.
arrowRightNum
.
splice
(
index
,
1
);
...
@@ -742,14 +755,9 @@ export default {
...
@@ -742,14 +755,9 @@ export default {
path
=
[
a
,
b
-
0.1
];
path
=
[
a
,
b
-
0.1
];
// 线条infowindow显示中间,保留六位转换字符串,否则有时候会出现一些问题
// 线条infowindow显示中间,保留六位转换字符串,否则有时候会出现一些问题
iten
.
infoPath
=
[
a
.
toFixed
(
6
),
b
.
toFixed
(
6
)];
iten
.
infoPath
=
[
a
.
toFixed
(
6
),
b
.
toFixed
(
6
)];
console
.
log
(
path
);
}
else
{
}
else
{
path
=
[
iten
.
path
[
0
],
iten
.
path
[
1
]
-
0.1
];
path
=
[
iten
.
path
[
0
],
iten
.
path
[
1
]
-
0.1
];
}
}
// const path =
// item.value == 1
// ? [iten.lnglat[0], iten.lnglat[1] - 0.1]
// : [iten.path[0], iten.path[1] - 0.1];
this
.
gaoMap
.
panTo
(
path
);
this
.
gaoMap
.
panTo
(
path
);
}
}
}
}
...
@@ -759,10 +767,7 @@ export default {
...
@@ -759,10 +767,7 @@ export default {
if
(
item
.
value
==
1
)
{
if
(
item
.
value
==
1
)
{
this
.
polylineInfoWindowShow
(
iten
,
lat
,
lng
);
this
.
polylineInfoWindowShow
(
iten
,
lat
,
lng
);
}
else
if
(
item
.
value
==
9
)
{
}
else
if
(
item
.
value
==
9
)
{
// 工作人员
// this.workerManInfoWindowShow(iten, lat, lng);
}
else
if
(
item
.
value
==
8
)
{
}
else
if
(
item
.
value
==
8
)
{
// this.trouleInfoWindowShow(iten, lat, lng);
}
else
{
}
else
{
// 其他设备
// 其他设备
this
.
diveceInfoWindowShow
(
iten
,
lat
,
lng
);
this
.
diveceInfoWindowShow
(
iten
,
lat
,
lng
);
...
@@ -781,12 +786,21 @@ export default {
...
@@ -781,12 +786,21 @@ export default {
};
};
// console.log(target.getOptions());
// console.log(target.getOptions());
// 如果是原地不动,就直接执行
// 如果是原地不动,就直接执行
if
(
iten
.
infoPath
[
0
]
==
lng
&&
iten
.
infoPath
[
1
]
==
lat
+
0.1
)
{
// console.log(iten.infoPath, lng, lat + 0.1);
console
.
log
(
iten
.
infoPath
[
0
]
-
lng
,
iten
.
infoPath
[
1
]
-
(
lat
+
0.1
));
// 因为计算问题,误差小于0.00001就没动
if
(
iten
.
infoPath
[
0
]
-
lng
>=
0
&&
iten
.
infoPath
[
0
]
-
lng
<=
0.00001
&&
iten
.
infoPath
[
1
]
-
(
lat
+
0.1
)
>=
0
&&
iten
.
infoPath
[
1
]
-
(
lat
+
0.1
)
<=
0.00001
)
{
// console.log('进来了')
this
.
gaoMap
.
leftListClick
=
false
;
this
.
gaoMap
.
polylineMouseOver
(
e
);
this
.
gaoMap
.
polylineMouseOver
(
e
);
target
.
setOptions
({
strokeColor
:
"#F7FE38"
});
target
.
setOptions
({
strokeColor
:
"#F7FE38"
});
return
;
return
;
}
}
// 因为地图移动的时候infowindow无法显示
// 因为地图移动的时候infowindow无法显示
this
.
gaoMap
.
handleInfoWindowOpenFunc
=
()
=>
{
this
.
gaoMap
.
handleInfoWindowOpenFunc
=
()
=>
{
this
.
gaoMap
.
polylineMouseOver
(
e
);
this
.
gaoMap
.
polylineMouseOver
(
e
);
...
@@ -804,7 +818,9 @@ export default {
...
@@ -804,7 +818,9 @@ export default {
lnglat
:
iten
.
path
,
lnglat
:
iten
.
path
,
};
};
// 如果是原地不动,就直接执行
// 如果是原地不动,就直接执行
if
(
iten
.
path
[
0
]
==
lng
&&
iten
.
path
[
1
]
==
lat
)
{
console
.
log
(
iten
.
path
,
lng
,
lat
);
if
(
iten
.
path
[
0
]
==
lng
&&
iten
.
path
[
1
]
==
lat
+
0.1
)
{
console
.
log
(
"9999999999"
);
this
.
gaoMap
.
infoOpen
(
e
);
this
.
gaoMap
.
infoOpen
(
e
);
return
;
return
;
}
}
...
...
gassafety-web/src/views/enterprise/mapView/index.vue
View file @
304d92e7
...
@@ -382,7 +382,7 @@ export default {
...
@@ -382,7 +382,7 @@ export default {
// 左边抽屉 内嵌scroll盒子的高
// 左边抽屉 内嵌scroll盒子的高
boxHeight
:
""
,
boxHeight
:
""
,
boxWidth
:
""
,
boxWidth
:
""
,
drawerOpacity
:
false
,
drawerOpacity
:
false
,
//抽屉是否收回
//抽屉是否收回
backFlag
:
true
,
backFlag
:
true
,
...
@@ -414,7 +414,7 @@ export default {
...
@@ -414,7 +414,7 @@ export default {
onResize
()
{
onResize
()
{
this
.
boxHeight
=
document
.
body
.
clientHeight
-
81
;
this
.
boxHeight
=
document
.
body
.
clientHeight
-
81
;
this
.
boxWidth
=
document
.
body
.
clientWidth
;
this
.
boxWidth
=
document
.
body
.
clientWidth
;
console
.
log
(
"挂在"
)
console
.
log
(
"挂在"
)
;
},
},
initMap
()
{
initMap
()
{
let
gaoMap
=
new
gaodeMap
(
"石家庄"
);
let
gaoMap
=
new
gaodeMap
(
"石家庄"
);
...
@@ -872,8 +872,16 @@ export default {
...
@@ -872,8 +872,16 @@ export default {
lnglat
:
iten
.
infoPath
,
lnglat
:
iten
.
infoPath
,
};
};
// console.log(target.getOptions());
// console.log(target.getOptions());
console
.
log
(
iten
.
infoPath
[
0
]
-
lng
,
iten
.
infoPath
[
1
]
-
(
lat
+
0.1
));
// 如果是原地不动,就直接执行
// 如果是原地不动,就直接执行
if
(
iten
.
infoPath
[
0
]
==
lng
&&
iten
.
infoPath
[
1
]
==
lat
+
0.1
)
{
// if (iten.infoPath[0] == lng && iten.infoPath[1] == lat + 0.1) {
if
(
iten
.
infoPath
[
0
]
-
lng
>=
0
&&
iten
.
infoPath
[
0
]
-
lng
<=
0.00001
&&
iten
.
infoPath
[
1
]
-
(
lat
+
0.1
)
>=
0
&&
iten
.
infoPath
[
1
]
-
(
lat
+
0.1
)
<=
0.00001
)
{
this
.
gaoMap
.
polylineMouseOver
(
e
);
this
.
gaoMap
.
polylineMouseOver
(
e
);
target
.
setOptions
({
strokeColor
:
"#F7FE38"
});
target
.
setOptions
({
strokeColor
:
"#F7FE38"
});
return
;
return
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment