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

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

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产成人精品午夜免费 | 成全视频在线观看免费 | 女同志 videos | 经典WC女厕所里TV | 日韩久久网| 国产精品视频播放 | 国产精品视频人人做人人爱 | 母爱成瘾在线观看 | 日韩影院在线 | 天天爱天天做天天爽天天躁 | 欧美老妪 | 天堂网在线.www天堂在线视频 | 国产一级持黄大片99久久 | 成人在线一区二区三区 | 成人午夜在线视频 | 美女露奶奶 | 日韩成片| 四虎影视4hu最新地址在线884 | 高清国语自产拍免费视频国产 | 亚洲欧美日韩中文字幕网址 | 日本mv精品中文字幕 | 免费一级特黄特色大片 | 99久久综合精品免费 | 热久久最新地址 | 日本护士撒尿xxxx欧美 | 超级毛片 | 亚洲天堂v| 美女自插 | 五月天精品在线 | 国产成人福利美女观看视频 | 日本黄a三级三级三级 | 我们中文在线观看免费完整版 | 精品日韩二区三区精品视频 | 日韩欧美一区二区三区中文精品 | 99在线视频精品费观看视 | 国模人体aⅴ | 娇妻中日久久持久久 | 亚洲日本中文字幕天天更新 | 国内精品自产拍在线观看91 | 日本一在线中文字幕天堂 | 美女用手扒开粉嫩的屁股 |