IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> 百度地图可视化之实现飞线动画 -> 正文阅读

[游戏开发]百度地图可视化之实现飞线动画

? ? 此文章最终实现的效果如下图:

使用mapv和mapvgl两个框架来实现百度地图的可视化。

?????Mapv 是一款地理信息可视化开源库,可以用来展示大量地理信息数据,点、线、面的数据,每种数据也有不同的展示类型,如直接打点、热力图、网格、聚合等方式展示数据。?

?????MapVGL,是一款基于WebGL的地理信息可视化库,可以用来展示大量基于3D的地理信息点线面数据。设计初衷主要是为了解决大数据量的三维地理数据展示问题及一些炫酷的三维效果。

? ? ? 绘制飞线动画,需要用到mapvgl中的FlyLineLayer,其用来展示轨迹飞线图层,是基于Three.js实现的,因此在使用前需要额外引入 mapvgl.threelayers包。

?实现步骤

1. 导入js库

<script type="text/javascript" src="https://api.map.baidu.com/api?type=webgl&v=1.0&ak=秘钥"></script>
<script src="https://mapv.baidu.com/gl/examples/static/common.js"></script>
<script src="https://mapv.baidu.com/build/mapv.js"></script>
<script src="https://code.bdstatic.com/npm/mapvgl@1.0.0-beta.54/dist/mapvgl.min.js"></script>
<script src="https://code.bdstatic.com/npm/mapvgl@1.0.0-beta.54/dist/mapvgl.threelayers.min.js"></script>

? ? ? ? 其中,与实现散点图比较,新增了mapvgl.threelayers包。

2. 编写容器组件及实现地图初始化

    <div id="map_container"></div>

? ? ? ? common.js方法中使用map_container为id来创建地图,因此使用common.js来初始化地图时,容器组件id需要与之统一。

 function initMyMap() {
    var cityCenter = mapv.utilCityCenter.getCenterByCityName('南京')
    //initMap 为common.js中初始化地图方法
    var map = initMap({
       center: [cityCenter.lng, cityCenter.lat],
       zoom: 6,
       tilt: 60,
       heading: 0,
       style: purpleStyle
    })
    return map
 }

3. 初始化数据源

? 利用城市中心点的经纬度来模拟数据,实际使用中可以通过接口返回数据。使用mapv中的工具类utilCityCenter的方法来得到城市名对应的经纬度数据。使用mapvgl中的内置工具BezierCurve来生成飞线数据。

???3.1 BezierCurve

????????BezierCurve是3D曲线生成器,通过传入起点和终点,生成带高度的贝塞尔曲线坐标集,可以用来生成飞线数据。

var curve = new mapvgl.BezierCurve({
    start:[12946640.989, 4846560.296],
    end:[12946348.509, 4846401.146]
})

? ? ? ? 属性有:

  • start:起点坐标
  • end:终点坐标

????????方法有:

  • getPoints({number}|{undefined}) :获取生成的曲线坐标集,传入的字段为曲线的分段数,默认为20
  • setOptions({Object} options):修改起点终点坐标等属性

????3.2 生成贝塞尔曲线坐标集? ? ? ??

?????????在准备数据源时,最重要一步就是需要生成贝塞尔曲线坐标集,生成步骤如下:

? ? ? ? ?3.2.1 实例化贝塞尔曲线对象

var curve = new mapvgl.BezierCurve()

????????3.2.2?设置起点和终点坐标

var startPoint = mapv.utilCityCenter.getCenterByCityName('上海')
var endPoint = mapv.utilCityCenter.getCenterByCityName('南京')
curve.setOptions({ //修改起点、终点坐标等属性
    start: [startPoint.lng, startPoint.lat],
    end: [endPoint.lng, endPoint.lat]
})

????????3.2.3?生成贝塞尔曲线坐标集? ??

var curveModelData = curve.getPoints()

????????最终完整的初始化数据函数如下:

function initData() {
    var data = []
    var cities = ['北京', '天津', '上海', '重庆', '石家庄', '太原', '呼和浩特', '哈尔滨', '长春',
        '沈阳', '济南', '南京', '合肥', '杭州', '南昌', '福州', '郑州', '武汉', '长沙', '广州',
        '南宁', '西安', '银川', '兰州', '西宁', '乌鲁木齐', '成都', '贵阳', '昆明', '拉萨', '海口'
    ]
    var random = 100 //模拟的飞线数量
    var curve = new mapvgl.BezierCurve();
    while (random--) {
        var startPoint = mapv.utilCityCenter.getCenterByCityName(cities[parseInt(Math.random() * cities.length, 10)])
        var endPoint = mapv.utilCityCenter.getCenterByCityName(cities[parseInt(Math.random() * cities.length, 10)])
        curve.setOptions({ //修改起点、终点坐标等属性
            start: [startPoint.lng, startPoint.lat],
            end: [endPoint.lng, endPoint.lat]
        })
        var curveModelData = curve.getPoints() //获取生成的曲线坐标集,传入的字段为曲线的分段数,默认值是20
        data.push({
            geometry: {
                type: 'LineString',
                coordinates: curveModelData
            },
            // 添加其他相关的数据
            properties: {
                count: Math.random()
            }
        })
    }
    return data
}

4.? 绘制数据源

? ? ? ? 4.1 初始化mapvgl.View图层管理器

var view = new mapvgl.View({
    map
});

? ? ? ? 4.2?初始化飞线对象

? ? ? ? 使用到了mapvgl.FlyLineLayer图层对象。

var flylineLayer = new mapvgl.FlyLineLayer({
    style: 'chaos',
    step: 0.3,
    color: 'rgba(33,242,214,0.3)',
    textureColor: function(data) {
        return data.properties.count > 0.5 ? '#ff0000' : '#56ccdd'
    },
    texturewidth: 20,
    textureLength: 10
})

?? ? ? ? 4.3 将飞线对象添加到图层中

view.addLayer(flylineLayer)

?? ? ? ? 4.4 将飞线对象与数据源进行绑定

flylineLayer.setData(data)

????????4.5?绘制数据源整合代码

function setData(map, data) {
    var view = new mapvgl.View({
        map
    });

    var flylineLayer = new mapvgl.FlyLineLayer({
        style: 'chaos',
        step: 0.3,
        color: 'rgba(33,242,214,0.3)',
        textureColor: function(data) {
            return data.properties.count > 0.5 ? '#ff0000' : '#56ccdd'
                // return '#ff0000'
        },
        texturewidth: 20,
        textureLength: 10
    })
    view.addLayer(flylineLayer)
    flylineLayer.setData(data)

}

5.? 函数的调用

var map = initMyMap()
const data = initData()
setData(map, data)

????????之后在浏览器中打开界面即可显示出相关的飞线动画图。

6. 飞线图层FlyLineLayer介绍

????用来展示轨迹飞线图层,基于Threejs实现,使用前需要额外引入mapvgl.threelayers包。

属性有:

  • style:飞线动画方式,取值 normal或chaos
    • normal:默认值,飞线动画速度均匀
    • chaos:飞线动画速度不均匀
  • color:底线颜色
  • textureColor:飞线动画颜色,string类型
  • textureWidth:飞线动画的宽度,number类型
  • textureLength:飞线动画的长度,占整条线的百分比,取值0~100
  • step:飞线动画的步长,越大动画速度越快,number类型

data内容格式为:

[{
    geometry: {
        type: 'LineString',
        coordinates: [
            [116.394191, 39.91334],
            [116.417259, 39.913672]
        ]
    }
}]

  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2021-10-11 17:50:06  更:2021-10-11 17:51:29 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 1:31:49-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码