数据可视化大屏百度地图GPS轨迹位置感知状态开发实战案例解析(百度地图jsAPI,包含缩放控件、点线覆盖物、弹窗、标注图标分类功能)

简介: 数据可视化大屏百度地图GPS轨迹位置感知状态开发实战案例解析(百度地图jsAPI,包含缩放控件、点线覆盖物、弹窗、标注图标分类功能)

系列文章目录

1.数据可视化大屏应急管理综合指挥调度系统完整案例详解(PHP-API、Echarts、百度地图)

2.数据可视化大屏百度地图API开发:停车场分布标注和检索静态版

3.百度地图高级开发:map.getDistance计算多点之间的距离并输入矩阵

4.百度地图高级开发:获取某范围半径圆形区域检索覆盖物内的所有标注的解决方案

5.百度地图高级开发:LBS服务实时定位覆盖范围内关键词标注的解决方案

6.百度地图:监听地图缩放自动显示和隐藏的富文本标签

7.百度地图POI多信息点标注开发说明文档(php+layui+mysql+百度javascript API2.0+echarts4.8)

8.百度地图开发:地图调起API(Web端)使用终点经纬度直接调用百度地图导航信息的解决方案

9.百度地图开发自定义信息窗口openInfoWindow样式的解决方案

10.百度地图开发mapStyle个性化地图styleJson的配色解决方案

11.百度地图标注maker图标按照分类显示不同的样式

12.百度地图开发:地图覆盖物实现纵横交错的交通网络


前言


f4e5c9e07cba47b3a19a6e3db5d2a93a.gif


项目说明

成品为数据可视化大屏的一组百度地图GPS轨迹位置感知状态的插件,主要实现的功能包括:


默认全部GPS的位置状态,分为在线设备位置展示和所有设备位置展示(包含离线未运行的设备);

指定GPS设备时间内的轨迹状态,默认2小时内的经纬度轨迹坐标线覆盖物的展示;

指定GPS设备状态展示,包含运行状态和定位状态,由后台API传输数据确定;

上述功能全部在SPA实现;


一、功能布局


76c39e6d7a0d40b0b767d575134bf4a6.png


基于layui开发,实现页面的容器构造,筛选查询功能。

<div class="layui-fluid">
    <div class="layui-card">
        <div class="layui-row">
            <form class="layui-form layui-form-pane" style="margin: 10px;">
                <div class="demoTable">
                    <div class="layui-form-item">
                        <div style="width: 100%;background:#fff;height: 15px;"></div>
                        <label class="layui-form-label">设备名称</label>
                        <div class="layui-input-inline"><select name="group_id" lay-filter="group_id" id="group_id"></select></div>
                        <div class="layui-input-inline"><input type="text" id="start_time" name="start_time" class="layui-input" placeholder="起始时间"></div>
                        <div class="layui-input-inline"><input type="text" id="end_time" name="end_time" class="layui-input" placeholder="截至时间"></div>
                        <div class="layui-inline"><a class="layui-btn layui-btn-normal" id="reload"><i class="layui-icon layui-icon-search"></i> 查询</a></div>
                        <div class="layui-inline"><a class="layui-btn layui-bg-cyan" id="all"><i class="layui-icon layui-icon-engine"></i> 所有设备</a></div>
                        <div class="layui-inline"><button class="layui-btn layui-btn-primary layui-bg-red" type="button" id="refresh"><i class="layui-icon layui-icon-refresh"></i> 重置</button></div>
                        <label class="layui-form-label status" style="width: 8%;">运行状态(<span id="temp1" class="alert1"></span>)</label>
                        <label class="layui-form-label status" style="width: 8%;">定位状态(<span id="temp2" class="alert1"></span>)</label>
                    </div>
                </div>
            </form>
        </div>
    </div>
    <!--Baidu map-->
    <div class="layui-card">
        <div id="map" style="width: 100%;height: 820px;"></div>
    </div>
</div>


二、状态灯CSS层叠样式表代码



        .alert1 {
            display: inline-block;
            width: 15px;
            height: 15px;
            line-height: 15px;
            border-radius: 50%;
            background: #e60000; /*FF0087*/
            margin: auto 5px;
        }
        .alert2 {
            display: inline-block;
            width: 15px;
            height: 15px;
            line-height: 15px;
            border-radius: 50%;
            background: #18a45b;
            margin: auto 5px;
        }


三、后台API通过ajax返回设备列表

加载layui组件,实现日期选择和下拉筛选功能。

    layui.use(['form', 'layer', 'laydate'], function () {
        var $ = layui.jquery;
        var form = layui.form;
        var laydate = layui.laydate;
        //时间选择器
        laydate.render({
            elem: '#start_time'
            , type: 'datetime'
            , value: from_time
        });
        laydate.render({
            elem: '#end_time'
            , type: 'datetime'
            , value: to_time
        });
        //获取设备列表;
        $.get('./api/api.php?act=getIotGPS&token=3cab7ce4142***', {}, function (res) {
            var memberHtml = '<option value="">在线GPS设备</option>'
            for (var i = 0; i < res.data.length; i++) {
                memberHtml += '<option value="' + res.data[i].group_id + '">' + res.data[i].device + '</option>'
            }
            $('#group_id').append(memberHtml);
            form.render();
        }, 'json');
    });


四、百度地图核心功能开发

异步加载数据封装函数

  //加载标注;
    /*
    * group_id,组Id
    * fromType,0过滤离线数据,1全部数据
    * */
    function getLockMap(group_id, start_time, end_time, fromType) {
        $.getJSON('./api/api.php?act=getIotGPS&token=3cab7ce41**', {
            group_id: group_id,
            start_time: start_time,
            end_time: end_time
        }, function (res) {
            //console.log(res.data);
            var points = [];
            var data = res.data;
            if (data) {
                for (var i = 0; i < data.length; i++) {
                    var lnglat = data[i].str_sdata.split(",");
                    points.push({
                        item_name: data[i].device,
                        item_mtime: data[i].mtime,
                        item_data: data[i].historyData,
                        poi_lng: lnglat[0],
                        poi_lat: lnglat[1],
                        propertyType: data[i].data.propertyType,
                        sensorStatus: data[i].data.sensorStatus,
                        sdata: data[i].sdata,
                        group_seq: data[i].group_seq,
                    })
                }
            }
            //加载地图;
            if (group_id == "") {
                //运行状态;
                $(".status").css("display", "none");
                //未指定设备时,加载全部设备标注;
                if (fromType == 1) {
                    intMap(points, 0);//全部数据
                } else {
                    intMap(filterGps(points), 0);//在线数据
                }
            } else {
                //判断运行状态和定位状态;
                var itemStatus = [], sdata2 = [];
                var propertyData = points[0].propertyType.split(",");
                var statusData = points[0].sensorStatus.split(",");
                var sdataData = points[0].sdata.split(",");
                for (var n = 0; n < propertyData.length; n++) {
                    //运行状态
                    if (propertyData[n] == "GPS定位") {
                        itemStatus[0] = statusData[n];
                    }
                    //定位状态;
                    if (propertyData[n] == "GPS状态") {
                        sdata2[0] = sdataData[n];
                    }
                }
                //console.log(itemStatus.toString());
                //console.log(sdata2.toString());
                //显示状态;
                $(".status").css("display", "block");
                if (itemStatus.toString() == "正常运行") {
                    $("#temp1").removeClass("alert1").addClass("alert2");
                }
                if (sdata2.toString() == "1") {
                    $("#temp2").removeClass("alert1").addClass("alert2");
                }
                //指定设备时,加载路线图;
                intMap(points, 1);
            }
        });
    }


百度地图封装

  var map;
    function intMap(markerArr, types) {
        map = new BMap.Map("map", {enableMapClick: false});
        map.centerAndZoom(new window.BMap.Point(markerArr[0].poi_lng, markerArr[0].poi_lat), 11);
        map.enableScrollWheelZoom();
        //添加缩放控件
        var ctrlNav = new window.BMap.NavigationControl({
            anchor: BMAP_ANCHOR_TOP_RIGHT,
            type: BMAP_NAVIGATION_CONTROL_LARGE
        });
        map.addControl(ctrlNav);
        //移除全部覆盖物
        map.clearOverlays();
        //加载标注;
        if (types == 0) {
            getMaker(markerArr);
        }
        //加载路线;
        if (types == 1) {
            makePolyLine(markerArr);
        }


标注展示



  var map;
    function intMap(markerArr, types) {
        map = new BMap.Map("map", {enableMapClick: false});
        map.centerAndZoom(new window.BMap.Point(markerArr[0].poi_lng, markerArr[0].poi_lat), 11);
        map.enableScrollWheelZoom();
        //添加缩放控件
        var ctrlNav = new window.BMap.NavigationControl({
            anchor: BMAP_ANCHOR_TOP_RIGHT,
            type: BMAP_NAVIGATION_CONTROL_LARGE
        });
        map.addControl(ctrlNav);
        //移除全部覆盖物
        map.clearOverlays();
        //加载标注;
        if (types == 0) {
            getMaker(markerArr);
        }
        //加载路线;
        if (types == 1) {
            makePolyLine(markerArr);
        }
   }


轨迹展示



 //起始路线图;
        function makePolyLine(points) {
            var sy = new BMap.Symbol(BMap_Symbol_SHAPE_BACKWARD_OPEN_ARROW, {
                scale: 0.5,//图标缩放大小
                strokeColor: '#fff',//设置矢量图标的线填充颜色
                strokeWeight: '1.5',//设置线宽
            });
            //var icons = new BMap.IconSequence(sy, '10', '20');
            //数据处理,创建polyline对象;
            var pois = [];
            var lineData = points[0].item_data;
            //var lng1 = lineData[0].sdata.split(",");
            //var lng2 = lineData[lineData.length - 1].sdata.split(",");
            //var point1 = new BMap.Point(lng1[0], lng1[1]);
            //var point2 = new BMap.Point(lng2[0], lng2[1]);
            //最后为准标注弹窗
            getMaker(markerArr);
            //起点标注;
            /* var marker1 = new BMap.Marker(point1);
             map.addOverlay(marker1);
             //终点标注;
             var marker2 = new BMap.Marker(point2);
             map.addOverlay(marker2);*/
            for (var n = 0; n < lineData.length; n++) {
                var d1 = lineData[n].sdata.split(",");
                pois.push(new BMap.Point(d1[0], d1[1]))
            }
            //console.log(pois);
            var polyline = new BMap.Polyline(pois, {
                enableEditing: false,//是否启用线编辑,默认为false
                enableClicking: true,//是否响应点击事件,默认为true
                //icons: [icons],
                strokeWeight: '8',//折线的宽度,以像素为单位
                strokeOpacity: 0.8,//折线的透明度,取值范围0 - 1
                strokeColor: "#18a45b" //折线颜色
            });
            map.addOverlay(polyline);
            //设置最佳视野POI;
            map.setViewport(pois);
        }


总结

百度地图开发平台提供的jsAPI功能比较详尽,同时对应版本的类库说明也比较具体。在实际开发的过程中,根据项目需求,需要对jsAPI进行多次的封装和调用。@漏刻有时

相关文章
|
8月前
|
人工智能 API 开发者
HarmonyOS Next~鸿蒙应用框架开发实战:Ability Kit与Accessibility Kit深度解析
本书深入解析HarmonyOS应用框架开发,聚焦Ability Kit与Accessibility Kit两大核心组件。Ability Kit通过FA/PA双引擎架构实现跨设备协同,支持分布式能力开发;Accessibility Kit提供无障碍服务构建方案,优化用户体验。内容涵盖设计理念、实践案例、调试优化及未来演进方向,助力开发者打造高效、包容的分布式应用,体现HarmonyOS生态价值。
492 27
|
8月前
|
人工智能 API 语音技术
HarmonyOS Next~鸿蒙AI功能开发:Core Speech Kit与Core Vision Kit的技术解析与实践
本文深入解析鸿蒙操作系统(HarmonyOS)中的Core Speech Kit与Core Vision Kit,探讨其在AI功能开发中的核心能力与实践方法。Core Speech Kit聚焦语音交互,提供语音识别、合成等功能,支持多场景应用;Core Vision Kit专注视觉处理,涵盖人脸检测、OCR等技术。文章还分析了两者的协同应用及生态发展趋势,展望未来AI技术与鸿蒙系统结合带来的智能交互新阶段。
531 31
|
8月前
|
人工智能 小程序 前端开发
【一步步开发AI运动小程序】十九、运动识别中如何解析RGBA帧图片?
本文介绍了如何将相机抽取的RGBA帧图像解析为`.jpg`或`.png`格式,适用于体测、赛事等场景。首先讲解了RGBA图像结构,其为一维数组,每四个元素表示一个像素的颜色与透明度值。接着通过`uni.createOffscreenCanvas()`创建离屏画布以减少绘制干扰,并提供代码实现,将RGBA数据逐像素绘制到画布上生成图片。最后说明了为何不直接使用拍照API及图像转换的调用频率建议,强调应先暂存帧数据,运动结束后再进行转换和上传,以优化性能。
|
8月前
|
索引
【Flutter 开发必备】AzListView 组件全解析,打造丝滑索引列表!
在 Flutter 开发中,AzListView 是实现字母索引分类列表的理想选择。它支持 A-Z 快速跳转、悬浮分组标题、自定义 UI 和高效性能,适用于通讯录、城市选择等场景。本文将详细解析 AzListView 的核心参数和实战示例,助你轻松实现流畅的索引列表。
391 7
|
8月前
|
数据可视化 测试技术 API
前后端分离开发:如何高效调试API?有工具 vs 无工具全解析
在前后端分离的开发模式中,API 调试的效率直接影响项目的质量和交付速度。通过本文的对比分析,我们可以看到无工具调试模式虽具备灵活性和代码复用能力,但在操作便利性和团队协作上稍显不足。而传统的外部调试工具带来了可视化、高效协作与扩展性,却可能存在工具切换带来的开发链路断层问题。Apipost-Hepler 融合了两者的优势,让开发者无需离开熟悉的 IDEA 环境,就能享受可视化调试工具的强大功能。
255 5
|
8月前
|
移动开发 前端开发 JavaScript
从入门到精通:H5游戏源码开发技术全解析与未来趋势洞察
H5游戏凭借其跨平台、易传播和开发成本低的优势,近年来发展迅猛。接下来,让我们深入了解 H5 游戏源码开发的技术教程以及未来的发展趋势。
|
9月前
|
存储 人工智能 程序员
通义灵码AI程序员实战:从零构建Python记账本应用的开发全解析
本文通过开发Python记账本应用的真实案例,展示通义灵码AI程序员2.0的代码生成能力。从需求分析到功能实现、界面升级及测试覆盖,AI程序员展现了需求转化、技术选型、测试驱动和代码可维护性等核心价值。文中详细解析了如何使用Python标准库和tkinter库实现命令行及图形化界面,并生成单元测试用例,确保应用的稳定性和可维护性。尽管AI工具显著提升开发效率,但用户仍需具备编程基础以进行调试和优化。
615 9
|
8月前
|
算法 测试技术 C语言
深入理解HTTP/2:nghttp2库源码解析及客户端实现示例
通过解析nghttp2库的源码和实现一个简单的HTTP/2客户端示例,本文详细介绍了HTTP/2的关键特性和nghttp2的核心实现。了解这些内容可以帮助开发者更好地理解HTTP/2协议,提高Web应用的性能和用户体验。对于实际开发中的应用,可以根据需要进一步优化和扩展代码,以满足具体需求。
803 29
|
8月前
|
前端开发 数据安全/隐私保护 CDN
二次元聚合短视频解析去水印系统源码
二次元聚合短视频解析去水印系统源码
312 4
|
8月前
|
JavaScript 算法 前端开发
JS数组操作方法全景图,全网最全构建完整知识网络!js数组操作方法全集(实现筛选转换、随机排序洗牌算法、复杂数据处理统计等情景详解,附大量源码和易错点解析)
这些方法提供了对数组的全面操作,包括搜索、遍历、转换和聚合等。通过分为原地操作方法、非原地操作方法和其他方法便于您理解和记忆,并熟悉他们各自的使用方法与使用范围。详细的案例与进阶使用,方便您理解数组操作的底层原理。链式调用的几个案例,让您玩转数组操作。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~

推荐镜像

更多
  • DNS