使用高德地图做了一个在地图展示点位,并通过点击,显示直播的功能,这个任务是为了之后大屏做准备。
这是一个能展示多个点标记,并在点击的时候弹出信息窗体,并在信息窗体中播放视频,且展示相关信息以及操作事件。
一、使用到的高德API介绍:
(一)、申请高德地图key
首先就是申请高德地图的key。
<script type="text/javascript"
src="https://webapi.amap.com/maps?v=1.4.15&key=xxxxxxxxxxxxxxx"></script>
在html文件中,需要先准备一个“容器”,即添加
<div id="container"></div>
(二)、创建地图
创建的同时可以给地图设置中心点、级别、显示模式、自定义样式等属性,这里我使用的分别是:缩放级别、是否监控地图容器尺寸变化,默认值为false、地图中心点坐标值。
var map = new AMap.Map("container", {
zoom: 8,
resizeEnable: true,
center: [116.397428, 39.90923],//中心点坐标
});
接着就是图层,默认是标准底图,但也可以添加其他图层,可以通过map.add
方法添加图层:
这里使用的是卫星地图,通过放置在右上角的切换按钮,点击切换标准地图或者卫星地图。
var satelliteLayer = new AMap.TileLayer.Satellite(); // 卫星图
通过点击事件切换地图:
// 切换地图类型
$("#map_footer_div div").click(function (e) {
e.preventDefault();
// 如果为true,是标准图,赋值地图类型状态为false,通过map.remove()方法去除卫星图。
if (mapFlag) {
mapFlag = false;
map.remove(satelliteLayer);
} else {
mapFlag = true;
// 如果mapflag为false,说明 是卫星图
map.add(satelliteLayer);
}
})
官方地图 JS API 提供了标准、卫星、路网、路况、建筑等多个图层,还有其他更加高级的图层。尝试了几个图层,还是很有意思的。
(三)、点标记
官方提供了在地图之上绘制覆盖物的能力,比如点标记 Marker、文本标记 Text、圆点标记 CircleMarker。
使用起来还是很简单的,添加一个默认样式的点标记。
var marker = new AMap.Marker({
position:[116.39, 39.9]//位置
})
map.add(marker);//添加到地图
map.remove(marker); // 移除的方法
(四)、事件功能和信息窗体
JS API 提供的Map、点标记、矢量图形的实例均支持事件,鼠标或者触摸操作均会触发相应的事件。我们通过给点标记绑定click
事件来简单了解事件系统和信息窗体的基本使用:文章来源:https://www.toymoban.com/news/detail-430638.html
var infoWindow = new AMap.InfoWindow({ //创建信息窗体
isCustom: true, //使用自定义窗体
content:'<div>信息窗体</div>', //信息窗体的内容可以是任意html片段
offset: new AMap.Pixel(16, -45)
});
var onMarkerClick = function(e) {
infoWindow.open(map, e.target.getPosition());//打开信息窗体
//e.target就是被点击的Marker
}
var marker = new AMap.Marker({
position: [116.481181, 39.989792]
})
map.add(marker);
marker.on('click',onMarkerClick);//绑定click事件
二、综合
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset=utf-8>
<meta name="viewport" id="viewport"
content="width=device-width,height=device-height,initial-scale=1.0, maximum-scale=1.0,minimum-scale=1.0,user-scalable=no" />
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
<meta name="format-detection" content="telephone=no, email=no" />
<script type='text/javascript' src="/gisapi/getscript"></script>
<title></title>
<style>
ul li {
list-style: none;
}
#map_footer {
position: fixed;
bottom: 0;
right: 0;
}
</style>
<body>
<div class="map_box" id="container"></div>
<!-- 底部切换 地图类型 -->
<footer id="map_footer">
<div style="display:flex;justify-content: center;align-items: center;" id="map_footer_div">
<div>
<!-- 普通地图 -->
<img id="map_nowx" style="display: inline-block; height:60px;" src="../images/map_nowx_active.png" alt=""></div>
<div>
<!-- 卫星地图 -->
<img id="map_havewx" style="display: inline-block; height:60px;" src="../images/map_havewx.png" alt="">
</div>
</div>
</footer>
<script src="../script/jquery-1.12.2.min.js"></script>
<script src="../script/flv.min.js"></script>
<script src="../script/doT.min.js"></script>
<script type="text/javascript" src="xxx"></script>
<!-- 使用:前端渲染引擎doT.js -->
<script id="dynamicDetailTemplate" type="text/x-dot-template">
<div style="border-radius: 15px;width:375px;">
<div id="monitorDiv">
<!-- 直播视频 -->
<video controls width="100%" height="210px" autoplay muted id="VideoObj" href="{{=it.url}}"></video>
</div>
<ul class="map_ul_right">
... <!-- 底部信息 -->
</ul>
</div>
</script>
<script>
var videoUrl;
var mapFlag = true; //为true则显示正常地图,false为卫星地图
var monitorList = []; // 地图信息
// 使用高德地图
var infoWindow = new AMap.InfoWindow({
offset: new AMap.Pixel(0, -30),
anchor: 'bottom-center',
});//信息窗口
// 高德地图的open事件
infoWindow.on('open', showVideo);
var satelliteLayer = new AMap.TileLayer.Satellite(); // 卫星图
var map = new AMap.Map("container", {
resizeEnable: true,
center: [119.47, 32.84],//中心点坐标
zoom: 8
});
$(document).ready(function () {
getMonitorList();
});
// 请求 点位数据的 接口
function getMonitorList() {
$.get("xxx",
function (res) {
console.log('地图信息', res);
monitorList = res.resultTable;
for (var j = 0; j < monitorList.length; j++) {
var marker = new AMap.Marker({
position: [monitorList[j].lon, monitorList[j].lat],
mapId: monitorList[j].f_698,// 标识
map: map,
icon: new AMap.Icon({
image: '../images/xxx.png', // 本地自定义图标位置
size: new AMap.Size(25, 25), //图标大小
imageSize: new AMap.Size(25, 25)
}),
});
// 给所有的点标注添加点击事件
AMap.event.addListener(marker, 'click', markerClick);
}
}
);
}
// 点击图标 触发事件
function markerClick(e) {
var windowInfo = {
monitorId: e.target.De.monitorId, //标识
}
// 请求 直播地址接口
ajax.syncPost("xxx", { bindid: e.target.De.monitorId },
function (ret) {
// 如果请求成功,说明有直播地址
if (ret.s) {
videoUrl = ret.o.flvUrl;
var dynamicDetailTemplate = $("#dynamicDetailTemplate").text();
var dynamicDetail = doT.template(dynamicDetailTemplate);
// 设置窗口内容和定位
infoWindow.setContent(dynamicDetail(windowInfo));
// 传入经纬度,信息窗体才会进行跟随
infoWindow.open(map, [e.target.De.position.lng, e.target.De.position.lat]);
}
}
);
}
// 定时器:不加定时器会导致视频的id找不到
function showVideo() {
setTimeout(function () {
playFlv(videoUrl, '#VideoObj');
}, 1000);
};
// 视频播放
function playFlv(url, id) {
if (flvjs.isSupported()) {
this.flvPlayer = flvjs.createPlayer({
type: "flv",
url,
});
this.flvPlayer.attachMediaElement(document.querySelector("#VideoObj"));
this.flvPlayer.load();
}
};
// 点击其他地方,关闭信息窗体
map.on('click', function () {
infoWindow.close();
});
// 切换地图类型
$("#map_footer_div div").click(function (e) {
e.preventDefault();
var map_id = $(this).find("img").attr("id");
if (map_id == "map_nowx") {
mapFlag = true;
if (mapFlag) {
$("#map_nowx").attr("src", "../images/map_nowx_active.png");
$("#map_havewx").attr("src", "../images/map_havewx.png");
map.remove(satelliteLayer);
}
} else if (map_id == "map_havewx") {
mapFlag = false;
// 如果mapflat为false,说明 是卫星图
if (!mapFlag) {
$("#map_havewx").attr("src", "../images/map_havewx_active.png");
$("#map_nowx").attr("src", "../images/map_nowx.png");
map.add(satelliteLayer);
}
}
})
</script>
</body>
</html>
文章来源地址https://www.toymoban.com/news/detail-430638.html
到了这里,关于使用高德地图展示点位和信息窗体展示数据及播放视频的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!