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中实现台风风圈绘制算法的更多相关文章
- C#中的GDI+图形绘制方法
GDI+图形绘制方法 1.首先对于绘制图形,必须的先将命名空间导入:using System.Drawing.Drawing2D; 2.然后在一个事件中写入程序 首先先将Graphics这个对象实例化 ...
- 【CImg】三角形绘制算法实现
这周的CV基础练习是简单的图形绘制:比如说矩形.三角形和圆心什么的.会发现其实矩形和圆形的实现思路都很直白,矩形只需要确认两个对角坐标就可以了,圆心只需要确认圆心和半径,接着就是简单的遍历各个像素点判 ...
- 如何在3D场景中在模型上面绘制摄取点
有些时候,我们在屏幕上面绘制一个摄取点,在单屏玩游戏的模式下,我们并不能觉得有什么不妥.但是最近VR的热火朝天,我们带上眼镜看双屏的时候,总觉得这个摄取点看着很不舒服. 这个问题该怎么解决?在这里我首 ...
- [BS-28] iOS中分页的几种算法
iOS中分页的几种算法 总记录数:totalRecord 每页最大记录数:maxResult 算法一: totalPage = totalRecord % maxResult == 0 ? total ...
- mahout中kmeans算法和Canopy算法实现原理
本文讲一下mahout中kmeans算法和Canopy算法实现原理. 一. Kmeans是一个很经典的聚类算法,我想大家都非常熟悉.虽然算法较为简单,在实际应用中却可以有不错的效果:其算法原理也决定了 ...
- 数据结构笔记01:编程面试过程中常见的10大算法(java)
以下是在编程面试中排名前10的算法相关的概念,我会通过一些简单的例子来阐述这些概念.由于完全掌握这些概念需要更多的努力,因此这份列表只是作为一个介绍.本文将从Java的角度看问题,包含下面的这些概念: ...
- 在WPF中自定义你的绘制(五)
原文:在WPF中自定义你的绘制(五) 在WPF中自定义你的绘制(五) ...
- 在WPF中自定义你的绘制(三)
原文:在WPF中自定义你的绘制(三) 在WPF中自定义你的绘制(三) ...
- 在WPF中自定义你的绘制(四)
原文:在WPF中自定义你的绘制(四) 在WPF中自定义你的绘制(四) ...
随机推荐
- maven-surefire-plugin
本文参考自:https://www.cnblogs.com/qyf404/p/5013694.html surefire是maven里执行测试用例(包括testNG,Junit,pojo)的插件,他能 ...
- 20145307第十周JAVA学习报告
教材学习内容总结 Java的网络编程 1.计算机网络概述 (1)路由器和交换机组成了核心的计算机网络,计算机只是这个网络上的节点以及控制等,通过光纤.网线等连接将设备连接起来,从而形成了一张巨大的计算 ...
- Jquery6 DOM 节点操作
学习要点: 1.创建节点 2.插入节点 3.包裹节点 4.节点操作 DOM 中有一个非常重要的功能,就是节点模型,也就是 DOM 中的“M”.页面中的元素结构就是通过这种节点模型来互相对应着的,通过这 ...
- 【前端】Vue.js实现简单价格计算器
价格计算器 实现效果: 实现代码及注释: <!DOCTYPE html> <html> <head> <title>价格计算器</title> ...
- windows环境下mysql的解压安装以及备份和还原
系统环境为server2012 1.下载mysql解压版,解压安装包到指定目录 2.在以上目录中,复制一份my-default.ini文件,重命名为my.ini,进行如下修改(按照需要): [mysq ...
- Student : IComparable<Student> 以及逆变和协变
IComparable<Student>是Student的父类,所以IComparable<Student>可以接收Student.但是在使用CompareTo方法的时候,必须 ...
- spark(三)从hbase取数据
前言 通过spark获取hbase数据的过程中,遇到了InputFormat.文章主要围绕InputFormat介绍.会牵扯到spark,mapreduce,hbase相关内容 InputFormat ...
- 【视觉基础知识】Bag of words 在图像中的应用
文章转载自:https://www.cnblogs.com/shihuajie/p/5782515.html BOW (bag of words) 模型简介 Bag of words模型最初被用在文本 ...
- 自学Jav测试代码三 Math类 & Date & GregorianCalendar类
2017-08-23 20:30:08 writer: pprp package test; import java.util.Date; import java.util.*; public cla ...
- Angular2-使用Augury来调试Angular2程序
参考: http://www.jianshu.com/p/efecaea287f2https://augury.angular.io/ https://augury.angular.io/pages/ ...