一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - Openlayers實現點閃爍擴散效果

Openlayers實現點閃爍擴散效果

2021-10-15 15:06gw依舊愛學習 JavaScript

這篇文章主要為大家詳細介紹了Openlayers實現點閃爍擴散效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了Openlayers實現點閃爍擴散效果的具體代碼,供大家參考,具體內容如下

點閃爍樣式:

Openlayers實現點閃爍擴散效果

DOM的樣式實現

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
/**橙色點擴散閃爍樣式*/
.point_animation{
 background: #ff9900;
 width: 6px;
 height: 6px;
 border: 2px #ff9900 solid;
 border-radius: 50%;
 position: absolute;
}
.point_animation p, .point_animation span{
 position: absolute;
 width: 4px;
 height: 4px;
 animation: point_animation 1.5s infinite;
 box-shadow: 0px 0px 1px #ff9900;
 margin: 0px;
 border-radius: 50%;
}
.point_animation span{
 animation-delay: 0.8s;
}
@keyframes point_animation{
 10% {
 transform: scale(1);
 }
 100% {
 transform: scale(8);
 }
}
/**紅色點擴散閃爍樣式*/
.css_animation{
 height:50px;
 width:50px;
 border-radius: 25px;
 background: rgba(255, 0, 0, 0.9);
 transform: scale(0);
 animation: mypoint 3s; 
 animation-iteration-count: infinite;
}
@keyframes mypoint{
 to{
 transform: scale(1.5);
 background: rgba(0, 0, 0, 0);
 }
}

在地圖上添加點—采用overlay添加DOM元素

需要用到Openlayers中的overlay元素,官方對于如何使用overlay做出了相關API說明

?
1
2
3
4
5
6
///創建overlay,element傳入的是存在于web中的DOM元素
var popup = new ol.Overlay({
 element: document.getElementById('popup')
});
popup.setPosition(coordinate);//設置overlay的位置
map.addOverlay(popup);//講overlay添加到地圖上

具體代碼

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>點擴散</title>
 <link rel="stylesheet" href="https://openlayers.org/en/v3.20.1/css/ol.css" type="text/css">
  <script src="https://openlayers.org/en/v3.20.1/build/ol.js"></script>
 <style>
 .point_animation{
  background: #ff9900;
  width: 6px;
  height: 6px;
  border: 2px #ff9900 solid;
  border-radius: 50%;
  position: absolute;
 }
 
 .point_animation p, .point_animation span{
  position: absolute;
  width: 4px;
  height: 4px;
  animation: point_animation 1.5s infinite;
  box-shadow: 0px 0px 1px #ff9900;
  margin: 0px;
  border-radius: 50%;
 }
 .point_animation span{
  animation-delay: 0.8s;
 }
 @keyframes point_animation{
  10% {
  transform: scale(1);
  }
  100% {
  transform: scale(8);
  }
 }
 .css_animation{
  height:50px;
  width:50px;
  border-radius: 25px;
  background: rgba(255, 0, 0, 0.9);
  transform: scale(0);
  animation: mypoint 3s;  
  animation-iteration-count: infinite;
 }
 @keyframes mypoint{
  to{
  transform: scale(1.5);
  background: rgba(0, 0, 0, 0);
  }
 }
 </style>
</head>
 
<body>
 <div id="container"></div>
 <script type="text/javascript">
 var baseLayer = new ol.layer.Tile({
  source: new ol.source.XYZ({
  url: "http://wprd0{1-4}.is.autonavi.com/appmaptile?lang=zh_cn&size=1&style=7&x={x}&y={y}&z={z}",
  }),
 });
 
 var map = new ol.Map({
  layers: [baseLayer],
  view: new ol.View({
  center: [104.5602,32.4070],
  projection: 'EPSG:4326',
  zoom: 4,
  extent: [-180, -90, 180, 90]
  }),
  target: "container",
  interactions:ol.interaction.defaults({
  doubleClickZoom: false
  }),
  controls:ol.control.defaults({
  zoom:false,
  attribution: false,
  }),
 });
 setFlashPoint()
 function setFlashPoint(){
  //第一種樣式
  var element = document.createElement("div");
  element.className = "point_animation";
  var p = document.createElement("p");
  var span = document.createElement("span");
  element.appendChild(p);
  element.appendChild(span);
  var point_overlay = new ol.Overlay({
  element: element,
  positioning: 'center-center',
  });
  map.addOverlay(point_overlay);
  point_overlay.setPosition([120,30]);
  //第二種樣式
  var ele = document.createElement("div");
  ele.className = "css_animation";
  var point_overlay2 = new ol.Overlay({
  element: ele,
  positioning: 'center-center',
  });
  map.addOverlay(point_overlay2);
  point_overlay2.setPosition([110,30]);
 }
 </script>
</body>
</html>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/guowenf/article/details/105915992

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲偷窥图区色 | 精品9e精品视频在线观看 | 情缘1完整版在线观看 | 色老板最新网站视频地址 | 图片亚洲va欧美va国产综合 | 精品手机在线1卡二卡3卡四卡 | 欧美不卡一区二区三区 | free性泰国娇小videos | 亚洲激情在线 | 国产精品夜夜爽张柏芝 | 爆操| 农夫69小说恋老妇小说 | 故意短裙公车被强好爽在线播放 | 国产黄频在线观看高清免费 | 久青草国产在线观看视频 | 91视频破解 | 91精品国产高清久久久久久 | 大陆国产精品视频 | 亚洲 欧美 国产 视频二区 | 激情综合色啪啪小说 | 95视频在线观看在线分类h片 | 天天综合天天影视色香欲俱全 | 日本xx高清视频免费观看 | 九九久久国产精品免费热6 九九精品视频一区二区三区 | 国内视频一区二区三区 | 国产香蕉一区二区精品视频 | 2048论坛永久入口 原创合集 | 久久99国产视频 | 草莓秋葵菠萝蜜绿巨人污 | 91在线播 | 忘忧草在线社区WWW日本直播 | 羞羞视频麻豆 | 四虎影视永久在线精品免费 | 高清不卡日本v在线二区 | 亚洲丰满女人ass硕大 | 久久久精品3d动漫一区二区三区 | 九九99九九精彩网站 | 国产精品合集一区二区 | 国产精品视频免费看 | 91久久偷偷做嫩草影院电 | 久久一本综合 |