Openlayers3中实现台风风圈绘制算法

2023-11-27 20:59

本文主要是介绍Openlayers3中实现台风风圈绘制算法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概述:

台风的风圈的NE、NW、SW、SE四个方位的影响范围是不一致,本文介绍一种简单的风圈的绘制方法,并在OL3中展示。


实现效果:



实现代码:

1、数据格式

			var Configs = {CIRCLE_CENTER_X:104.21390114106414,CIRCLE_CENTER_Y:35.847595169932646,CIRCLE_R:{"SE":0.5,"NE":0.3,"NW":0.2,"SW":0.5}};

2、关键代码

            var wkt = "POLYGON((";var wkt0 = "", _interval = 6;for(var i=0;i<360/_interval;i++){var _r = 0;var _ang = i*_interval;if(_ang>0&&_ang<=90){_r = Configs.CIRCLE_R.NE;}else if(_ang>90&&_ang<=180){_r = Configs.CIRCLE_R.NW;}else if(_ang>180&&_ang<=270){_r = Configs.CIRCLE_R.SW;}else{_r = Configs.CIRCLE_R.SE;}var x = Configs.CIRCLE_CENTER_X + _r * Math.cos(_ang * 3.14 /180);var y = Configs.CIRCLE_CENTER_Y + _r  * Math.sin(_ang * 3.14/180);wkt = wkt+""+x+" "+y+", ";if(i===0){wkt0 = ""+x+" "+y+"";}}wkt = wkt+wkt0+"))";

3、完整代码

<html xmlns="http://www.w3.org/1999/xhtml">
<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>Ol3 draw</title><link rel="stylesheet" type="text/css" href="../../../plugin/ol3/css/ol.css"/><style type="text/css">body, #map {border: 0px;margin: 0px;padding: 0px;width: 100%;height: 100%;font-size: 13px;}</style><script type="text/javascript" src="../../../plugin/ol3/build/ol.js"></script><script type="text/javascript" src="../../../plugin/jquery/jquery-1.8.3.js"></script><script type="text/javascript">var wktformat = new ol.format.WKT();function init(){var untiled = new ol.layer.Image({source: new ol.source.ImageWMS({ratio: 1,url: 'http://localhost:8080/geoserver/lzugis/wms',params: {'FORMAT': 'image/png','VERSION': '1.1.1',LAYERS: 'lzugis:province',STYLES: ''},serverType: 'geoserver'})});var Configs = {CIRCLE_CENTER_X:104.21390114106414,CIRCLE_CENTER_Y:35.847595169932646,CIRCLE_R:{"SE":0.5,"NE":0.3,"NW":0.2,"SW":0.5}};var wkt = "POLYGON((";var wkt0 = "", _interval = 6;for(var i=0;i<360/_interval;i++){var _r = 0;var _ang = i*_interval;if(_ang>0&&_ang<=90){_r = Configs.CIRCLE_R.NE;}else if(_ang>90&&_ang<=180){_r = Configs.CIRCLE_R.NW;}else if(_ang>180&&_ang<=270){_r = Configs.CIRCLE_R.SW;}else{_r = Configs.CIRCLE_R.SE;}var x = Configs.CIRCLE_CENTER_X + _r * Math.cos(_ang * 3.14 /180);var y = Configs.CIRCLE_CENTER_Y + _r  * Math.sin(_ang * 3.14/180);wkt = wkt+""+x+" "+y+", ";if(i===0){wkt0 = ""+x+" "+y+"";}}wkt = wkt+wkt0+"))";var features = new Array();features.push(wktformat.readFeature(wkt));features.push(wktformat.readFeature("POINT("+Configs.CIRCLE_CENTER_X+" "+Configs.CIRCLE_CENTER_Y+")"));var styleFunc = function(feature, resolution){var index = feature.get("index");return new ol.style.Style({fill: new ol.style.Fill({color: 'rgba(255, 0, 0, 0.2)'}),stroke: new ol.style.Stroke({color: '#ffcc33',width: 2}),image: new ol.style.Circle({radius: 4,fill: new ol.style.Fill({color: '#ff0000'})})});};var vector = new ol.layer.Vector({source: new ol.source.Vector({features: features}),style:styleFunc});var map = new ol.Map({controls: ol.control.defaults({attribution: false}),target: 'map',layers: [untiled,vector],view: new ol.View({projection: new ol.proj.Projection({code: 'EPSG:4326',units: 'degrees'}),center: [103.847, 36.0473],zoom: 4})});}</script>
</head>
<body onLoad="init()">
<div id="map">
</div>
</body>
</html>

-----------------------------------------------------------------------------------------------

技术博客

CSDN:http://blog.csdn.NET/gisshixisheng

博客园:http://www.cnblogs.com/lzugis/

在线教程

http://edu.csdn.Net/course/detail/799

Github

https://github.com/lzugis/

联系方式

q       q:1004740957

e-mail:niujp08@qq.com

公众号:lzugis15

Q Q 群:452117357(webgis)

             337469080(Android)

这篇关于Openlayers3中实现台风风圈绘制算法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/428464

相关文章

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr

NFS实现多服务器文件的共享的方法步骤

《NFS实现多服务器文件的共享的方法步骤》NFS允许网络中的计算机之间共享资源,客户端可以透明地读写远端NFS服务器上的文件,本文就来介绍一下NFS实现多服务器文件的共享的方法步骤,感兴趣的可以了解一... 目录一、简介二、部署1、准备1、服务端和客户端:安装nfs-utils2、服务端:创建共享目录3、服

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

Python实现高效地读写大型文件

《Python实现高效地读写大型文件》Python如何读写的是大型文件,有没有什么方法来提高效率呢,这篇文章就来和大家聊聊如何在Python中高效地读写大型文件,需要的可以了解下... 目录一、逐行读取大型文件二、分块读取大型文件三、使用 mmap 模块进行内存映射文件操作(适用于大文件)四、使用 pand

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一

Python xmltodict实现简化XML数据处理

《Pythonxmltodict实现简化XML数据处理》Python社区为提供了xmltodict库,它专为简化XML与Python数据结构的转换而设计,本文主要来为大家介绍一下如何使用xmltod... 目录一、引言二、XMLtodict介绍设计理念适用场景三、功能参数与属性1、parse函数2、unpa

C#实现获得某个枚举的所有名称

《C#实现获得某个枚举的所有名称》这篇文章主要为大家详细介绍了C#如何实现获得某个枚举的所有名称,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... C#中获得某个枚举的所有名称using System;using System.Collections.Generic;usi

Go语言实现将中文转化为拼音功能

《Go语言实现将中文转化为拼音功能》这篇文章主要为大家详细介绍了Go语言中如何实现将中文转化为拼音功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 有这么一个需求:新用户入职 创建一系列账号比较麻烦,打算通过接口传入姓名进行初始化。想把姓名转化成拼音。因为有些账号即需要中文也需要英

C# 读写ini文件操作实现

《C#读写ini文件操作实现》本文主要介绍了C#读写ini文件操作实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录一、INI文件结构二、读取INI文件中的数据在C#应用程序中,常将INI文件作为配置文件,用于存储应用程序的