数据可视化大屏高德地图javascript webAPI开发的智慧治安物联网管理系统实战解析(web GIS、3D视图、个性化地图、标注、涟漪动画、自定义弹窗、3D控件)

简介: 数据可视化大屏高德地图javascript webAPI开发的智慧治安物联网管理系统实战解析(web GIS、3D视图、个性化地图、标注、涟漪动画、自定义弹窗、3D控件)

高德地图开发系列文章目录

地图开发实战案例:高德地图弧线连接线标注

高德地图开发智慧社区网格化数据格式产生的无法单击事件的解决方案

高德地图进阶开发实战案例(4):计算骑行的距离和时间

高德地图进阶开发实战案例(9):涟漪动画标注的实现方案

高德地图进阶开发实战案例(2):电子围栏(多边形的绘制)的展示

高德地图进阶开发实战案例(5):矩形可视范围的东北西南角经纬度的获取

高德地图进阶开发实战案例(6):添加自定义图片覆盖物图层获取可视范围经纬度的解决方案

高德地图进阶开发实战案例(10):地图选取起终点OD位置经纬度的驾车规划路线

高德地图web服务API接口开发:获取IP定位显示当前位置的天气预报解决方案

高德地图进阶开发实战案例(7):点是否在多边形内和内外部的数量统计的解决方案

高德地图进阶开发实战案例(12):热力图模拟传播范围以及小区兴趣点POI经纬度的获取方法



b78f6f8c741b4e72bedf276f8dfed3e7.gif


文章目录

高德地图开发系列文章目录

前言

一、项目说明

二、核心代码开发

1.引入库

2.构建DOM容器

3.高德地图开发

(1)初始化地图

(2)个性化地图皮肤

(3)3D控件

(4)信息弹窗

(5)涟漪动画

总结


前言

在数据可视化大屏的开发中,牵涉到地图类开发(即WEB GIS)的,主要使用百度地图、高德地图和腾讯地图。对于国内地图类开发平台而言,百度和高德是做WEB GIS的不二选择,腾讯地图基本使用于小程序类的开发。


一、项目说明

本系统是基于物联网端的智慧治安管理系统,主要是针对执勤人员的分布位置感知状态、执勤设备告警的数据展示分析:


设备自带网络传输功能,可实时将当前位置的经纬度传送是数据库;但采集的经纬度信息为wgs84标准,在大屏读取时,需要转换为高德的火星系坐标;

标注需要分类:告警状态和正常执行状态,采用涟漪动画效果实现;

单击标注需要实现自定义富文本弹窗;

大屏界面UI设计图如下:


f00389e3fa46406f818a27718f9a4e98.jpg


二、核心代码开发

1.引入库

代码如下(示例):

  <!--高德地图核心JS库-->
    <script src="https://webapi.amap.com/maps?v=1.4.15&key=eff803c70ebbfb***"></script>

高德地图地图开发引入时需要注意:

  • 不同版本的v=1.4.15的差异,尤其是在复制官方案例的时候,一定要注意版本的切换,不然就会遇见同样代码无法运行的情况;
  • 除了引入webapi库外,需要根据不同的需求,引入高德的css层叠样式表;

2.构建DOM容器

代码如下(示例):

   <div id="map"></div>

地图采用自适应浏览器的模式,具体见层叠样式表:

/*地图定位*/
.alert {
    width: 288px;
    height: 190px;
    padding-top: 30px;
    background: url("../images/alert.png") no-repeat top center;
}
#map {
    width: 98.5%;
    height: 100%;
    text-align: center;
}
.mapBg {
    background: url(../images/map_border.png) no-repeat left center;
    background-size: contain;
}

3.高德地图开发

(1)初始化地图

    var map = new AMap.Map('map', {
        resizeEnable: true,
        zoom: 16,
        center: [116.397428, 39.90923],
        viewMode: '3D',//3D视野
        pinch: 45,
        showLabel: true,
        //features: ['bg', 'road', 'building'],
        showIndoorMap: true, //关闭室内地图
    });

(2)个性化地图皮肤

根据自己的web key,自定义好地图皮肤,将对应的styles引入即可。

/*个性化地图皮肤*/
    map.setMapStyle('amap://styles/0dec7c328b627a31575c8ec13119ea72');

(3)3D控件

  /*3D控件*/
    AMap.plugin(['AMap.ControlBar',], function () {
        map.addControl(new AMap.ControlBar());
    });

(4)信息弹窗

 var infoWindow = new AMap.InfoWindow({offset: new AMap.Pixel(0, -30)});
    for (var i = 0; i < lnglats.length; i++) {
        var pos = lnglats[i].point;
        var id = lnglats[i].id;
        var vvvccc = pos[0] + ',' + pos[1];
        var vvv = vvvccc.split(",");
        var vcvcx0 = parseFloat(vvv[0]);
        var vcvcx1 = parseFloat(vvv[1]);
        vvv[0] = parseFloat(vcvcx0);
        vvv[1] = parseFloat(vcvcx1);
        var marker = new AMap.Marker({
            position: vvv,
            map: map
        });
        marker.content = "<p class='cardsBg'></p>";
        marker.on('click', markerClick);
        //marker.emit('click', {target: marker});
        var text = new AMap.Text({
            text: ' ',
            textAlign: 'center',
            verticalAlign: 'middle', //middle 、bottom
            draggable: true,
            cursor: 'pointer',
            angle: 10,
            style: {
                'width': '15px',
                'height': '15px',
                'border-radius': '50%',
                'border-width': 0,
                'text-align': 'center',
                'font-size': '24px',
                'color': 'blue',
                'background-color': lnglats[i].color,
                'animation': lnglats[i].animations + ' 1s infinite',
            },
            position: vvv,//lnglats[i].point,
        })
        text.setMap(this.map);
    }
    //弹出窗口;
    function markerClick(e) {
        infoWindow.setContent(e.target.content);
        infoWindow.open(map, e.target.getPosition());
    }
    map.setFitView();

(5)涟漪动画

在高德地图中,将标注选用new AMap.Text格式,采用赋值样式,加载animation动画实现。

  style: {
                'width': '15px',
                'height': '15px',
                'border-radius': '50%',
                'border-width': 0,
                'text-align': 'center',
                'font-size': '24px',
                'color': 'blue',
                'background-color': lnglats[i].color,
                'animation': lnglats[i].animations + ' 1s infinite',
            }


总结



最终呈现动图。

在开发过程中,涟漪动画的实现,自定义富文本弹窗,是重点和难点,除了对高德地图样例的理解和调试外,更需要结合实际的UI界面进行实现。@漏刻有时

相关实践学习
阿里云AIoT物联网开发实战
本课程将由物联网专家带你熟悉阿里云AIoT物联网领域全套云产品,7天轻松搭建基于Arduino的端到端物联网场景应用。 开始学习前,请先开通下方两个云产品,让学习更流畅: IoT物联网平台:https://iot.console.aliyun.com/ LinkWAN物联网络管理平台:https://linkwan.console.aliyun.com/service-open
相关文章
|
并行计算 Java 数据处理
SpringBoot高级并发实践:自定义线程池与@Async异步调用深度解析
SpringBoot高级并发实践:自定义线程池与@Async异步调用深度解析
1114 0
|
人工智能 自然语言处理 前端开发
SpringBoot + 通义千问 + 自定义React组件:支持EventStream数据解析的技术实践
【10月更文挑战第7天】在现代Web开发中,集成多种技术栈以实现复杂的功能需求已成为常态。本文将详细介绍如何使用SpringBoot作为后端框架,结合阿里巴巴的通义千问(一个强大的自然语言处理服务),并通过自定义React组件来支持服务器发送事件(SSE, Server-Sent Events)的EventStream数据解析。这一组合不仅能够实现高效的实时通信,还能利用AI技术提升用户体验。
1342 2
|
机器学习/深度学习 JavaScript 前端开发
JavaScript 弹窗
JavaScript 弹窗
349 2
|
Web App开发 移动开发 前端开发
React音频播放器样式自定义全解析:从入门到避坑指南
在React中使用HTML5原生&lt;audio&gt;标签时,开发者常面临视觉一致性缺失、样式定制局限和交互体验割裂等问题。通过隐藏原生控件并构建自定义UI层,可以实现完全可控的播放器视觉风格,避免状态不同步等典型问题。结合事件监听、进度条拖拽、浏览器兼容性处理及性能优化技巧,可构建高性能、可维护的音频组件,满足跨平台需求。建议优先使用成熟音频库(如react-player),仅在深度定制需求时采用原生方案。
563 12
|
设计模式 XML Java
【23种设计模式·全精解析 | 自定义Spring框架篇】Spring核心源码分析+自定义Spring的IOC功能,依赖注入功能
本文详细介绍了Spring框架的核心功能,并通过手写自定义Spring框架的方式,深入理解了Spring的IOC(控制反转)和DI(依赖注入)功能,并且学会实际运用设计模式到真实开发中。
【23种设计模式·全精解析 | 自定义Spring框架篇】Spring核心源码分析+自定义Spring的IOC功能,依赖注入功能
|
弹性计算 网络协议 Ubuntu
如何在阿里云国际版Linux云服务器中自定义配置DNS
如何在阿里云国际版Linux云服务器中自定义配置DNS
|
JavaScript
js学习--开屏弹窗
js学习--开屏弹窗
205 1
|
数据采集 前端开发 开发者
Angular表单控件详解:掌握模板驱动与响应式表单的精髓,让Web应用中的数据采集工作变得高效又简单,彻底告别繁琐的表单处理流程
【8月更文挑战第31天】表单是 Web 应用的关键组件,用于用户登录、注册及信息提交。Angular 作为成熟前端框架,提供了强大的表单处理功能,包括模板驱动与响应式表单。本文通过技术博客形式,详细介绍这两种表单控件,并提供示例代码,展示如何利用它们简化表单处理流程,提高开发效率。首先介绍简单的模板驱动表单,然后讲解基于 RxJS 的响应式表单,适用于复杂逻辑。通过本文,你将学会如何高效地使用 Angular 表单控件,提升应用的用户体验。
279 1
|
程序员 开发者 Python
深度解析Python中的元编程:从装饰器到自定义类创建工具
【10月更文挑战第5天】在现代软件开发中,元编程是一种高级技术,它允许程序员编写能够生成或修改其他程序的代码。这使得开发者可以更灵活地控制和扩展他们的应用逻辑。Python作为一种动态类型语言,提供了丰富的元编程特性,如装饰器、元类以及动态函数和类的创建等。本文将深入探讨这些特性,并通过具体的代码示例来展示如何有效地利用它们。
342 0
|
数据处理 Python
Django视图:构建动态Web页面的核心技术
Django视图:构建动态Web页面的核心技术

热门文章

最新文章

推荐镜像

更多
  • DNS