Leaflet实现风场流动效果

插件下载地址https://download.csdn.net/download/qq_35131811/10674594

Leaflet实现风场流动效果

1、将leaflet-velocity相关的文件copy到项目目录下,并引用到页面里

2、新建layer并添加到map里,生成的风场效果可以通过下图所示参数进行控制,

也可以直接更改leaflet-velocity.js,如下图:

数据格式见wind-gbr.json,至此已经可以显示风场效果。

3、该插件以正南方向为正方向,可以根据实际情况自己调整方向,我这里调整为正北。该测试数据是100*100的格点数据,是经过如下方式计算UV分量之后的效果,也就是转换为正北方向之后的效果,见下图便可理解。

 

4、UV分量的计算方式

 

dir = (270.0-方向)*Math.PI/180.0);

U = (速度* Math.cos(dir );

V = (速度* Math.sin(dir );

因为我要将方向由正南方向转为正北方向,故方向值加180,做如下处理

在做更改之后,也需要更改leaflet-velocity.js中关于风向提示的计算方式,

5、数据格式说明

[

    {

        "header":{

            "parameterUnit":"m/s",//单位

            "parameterNumber":2,//固定值

            "dx":1,//间隔 根据生产的数据自定义

            "dy":1,//间隔 根据生产的数据自定义

            "parameterNumberName":"eastward_wind",//无意义值,可默认为eastward_wind

            "la1":-6.5,// 纬度

            "la2":-18.5,// 纬度

            "parameterCategory":2,// 固定值

            "lo2":146,// 经度

            "nx":14,//数量

            "ny":22,//数量

            "refTime":"2017-02-01 23:00:00",//时间

            "lo1":133// 经度

        },

        "data":[U分量数据]

    },

    {

        "header":{

            "parameterUnit":"m/s",

            "parameterNumber":3,

            "dx":1,

            "dy":1,

            "parameterNumberName":"northward_wind",

            "la1":-6.5,

            "la2":-18.5,

            "parameterCategory":2,

            "lo2":146,

            "nx":14,

            "ny":22,

            "refTime":"2017-02-01 23:00:00",

            "lo1":133

        },

        "data":[V分量数据]

    }

]
--------------------- 
作者:高傲的孤独 
来源:CSDN 
原文:https://blog.csdn.net/qq_35131811/article/details/82761238 
版权声明:本文为博主原创文章,转载请附上博文链接!

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
leaflet地图风场是利用leaflet.js这个JavaScript库来展示风场数据的一种技术。风场数据包括风速和风向,通过可视化展示在地图上的方式,提供了直观且易于理解的风场信息。 leaflet.js是一个轻量级的地图库,可以实现在网页上展示交互式地图。它具有简洁的API接口和丰富的插件支持,非常适合用于构建交互式地图应用。通过leaflet地图风场技术,我们可以将风场数据与地图相结合,实现在地图上显示风速和风向的效果leaflet地图风场实现过程一般包括以下几个步骤: 1. 数据准备:首先需要获取风场数据,通常是通过气象数据源获取到的。这些数据包括了风速和风向的信息。可以将这些数据转换成leaflet可识别的格式,如GeoJSON格式。 2. 创建地图:使用leaflet.js库创建一个地图容器,并设置初始的地图中心点、缩放级别等。 3. 添加风场图层:利用leaflet的图层功能,将风场数据添加到地图上。可以使用插件或自定义的方式来实现。 4. 风场可视化:对风场数据进行可视化处理,通常是将风速和风向信息转换成箭头、色阶等形式展示在地图上。可以利用leaflet的样式设置功能来实现。 5. 交互功能:为了增强用户体验,通常还可以添加一些交互功能,如鼠标悬停显示具体数值、点击风场图层显示风场数据的详细信息等。 通过leaflet地图风场技术,我们可以直观地了解不同地区的风场情况,对风能利用等方面提供支持。因其容易上手、功能丰富和灵活性强等特点,越来越多的人开始使用leaflet地图风场来展示和分析风场数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值