打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
Arcgis js多线程克里金插值初体验
最近做关于雨量插值的项目,本来使用后台的GP工具做的,但是处理时间比较长需要十几秒钟左右,所以研究怎么通过前台来计算。

参考下克里金例子,思路是生成要计算区域的100乘以100网格,然后通过函数进行计算该网格克里金值,最后利用网格和值进行渲染,使用该方法绘制速度有所提高,七秒左右就能绘制完成,不过速度还是能提高的,提高的要诀是使用多线程。

多线程使用比较简单,只要new worker('krigingworker.js'),然后通过postmessage以及onmessage主线程和多线程中通讯。

下面给出例子

var myWorker = new Worker("krigingworker.js");myWorker.postMessage = myWorker.webkitPostMessage || myWorker.postMessage;myWorker.postMessage();

krigingworker.js中

importScripts("kriging.js")self.postMessage = self.webkitPostMessage || self.postMessage;self.onmessage = function(e) {self.postMessage();

worker中使用别的脚本要使用importScripts导入,当需要传递参数可以transferable object(通讯时会比较快,参考worker使用),本次项目中使用Float64Array.看几个初始化范例

//定义一个字节为10248的Float64Arrayvar buffer=new ArrayBuffer(10248)var a =new Float64Array(buffer);//定义一个长度为1000的Float64Arrayvar a =new Float64Array(1000);//定义一个[1,1,1]的Float64Arrayvar a =new Float64Array([1,1,1])

我们尝试定义一个并接收到数据

var size =1000;var result = new ArrayBuffer(size);var gridPoint = new Float64Array(result);self.postMessage(gridPoint.buffer, [gridPoint.buffer]);
myWorker.onmessage = function(e) {var data = new Float64Array(e.data);

最后结果如图


本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
【转载】HTML5之Javascript多线程
Web Worker 使用教程
一文带你看懂 Web Worker
JS判断数组中是否包含某一项
js变量
Three.js Demo源码分析
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服