关于用OpenLayer实现加载高德地图实时路况的一个尝试

编程入门 行业动态 更新时间:2024-10-07 00:17:42

关于用OpenLayer实现加载高德地图实时<a href=https://www.elefans.com/category/jswz/34/1757535.html style=路况的一个尝试"/>

关于用OpenLayer实现加载高德地图实时路况的一个尝试

更新于2019-03-04

前言:前一段时间,我在一个交流群里发了一个关于用python爬取百度地图的一个poi点,群里有一个人说,如果你能爬取高德地图的车流量我可以帮你介绍工作,帮一个大学教授那工作,我当时就想笑,爬取高德地图的车流量,兄弟你想多了吧。人家付费一年收你几十万,你居然想爬取,高德地图的实时路况他没有数据,返回的是切片,高德地图官方连切片地址都不想让你找到。废话不多说开始尝试。

先看张图:

一、实时路况的原理

现在获得实时路况的数据,是浮动车数据实现的,能获取数据有以下两种可能:

1、政府机构主导

2、出租车公司提供

二、关于切片函数

        function getNavmapTraficLayer() {return new ol.layer.Tile({source: new ol.source.XYZ({url: '=1.0&;t=1&x={x}&y={y}&z={z}&&t=1534941945936'//7,8}),projection: projection});}var nana = getNavmapTraficLayer();

这里面有四个参数,x,y,z,t   这里面的前三个参数都很好解决,只有最后一个这个应该是时间t,关于这个时间表示的是啥,格里历日期还是啥,我还看没明白,传这个数据到底有啥用,实时路况,数据在不断的变,这个就是在获取不同的时刻数据,哪能现在怎么解决这个t呢?

参数t解决方案:由@robbin113  提供的

参数t是由当地时间(年、月、日、时、分、秒)转化成long类型具体代码如下

        //获取当前时间var nowDate = new Date();var year = nowDate.getFullYear();var month = nowDate.getMonth() + 1;var today = nowDate.getDate();var hours = nowDate.getHours();var minutes = nowDate.getMinutes();var seconds = nowDate.getSeconds();if (month >= 1 && month<= 9) {month = "0" + month;}if (today >= 1 && today <= 9) {today = "0" + today;}var currentdate = year + "-" + month + "-" + today + " " + hours + ":" + minutes + ":" + seconds;var longTime = new Date(currentdate.replace(new RegExp("-", "gm"), "/")).getTime();

三、完整demo

        var projection = ol.proj.get("EPSG:4326");function getNavmapLayer() {return new ol.layer.Tile({source: new ol.source.XYZ({url: '={x}&y={y}&z={z}&lang=zh_cn&size=1&scale=1&style=8'//7,8}),projection: projection});}
function getNavmapTraficLayer(longTime) {return new ol.layer.Tile({source: new ol.source.XYZ({url: '=1.0&;t=1&x={x}&y={y}&z={z}&&t=longTime'//7,8}),projection: projection});}var nana = getNavmapTraficLayer(longTime);var navlayer = getNavmapLayer();var map = new ol.Map({layers: [navlayer, nana, vector],view: new ol.View({center: [116.46, 39.92],projection: 'EPSG:4326',zoom: 4}),target: 'map'});

经检验与高德官网的实时路况相同,唯一缺点就是要加载高德路况,否则会有偏移,当然也可以对路况切片进行偏移矫正

更多推荐

关于用OpenLayer实现加载高德地图实时路况的一个尝试

本文发布于:2024-02-13 08:34:15,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1757634.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:路况   实时   加载   地图   OpenLayer

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!