ArcGIS JS 3.x使用webgl绘制热力图
ArcGIS Js Api 3.x 热力图在数据量达到三万左右的时候,绘制速度不尽人意,数据量再大些,缩放时候就会很卡,非常影响客户体验。
参考了一下网上webgl热力图,能达到更流畅的绘制的要求。(参考webgl-heatmap和heatmap-layer-js)webgl热力图使用很简单,只需要把屏幕坐标和权重设置到好就行,如下示例
heatmap.addPoints([{x:x, y:y, size:size, intensity:intensity}]);
依靠这个插件进行下热力图扩展,热力图插件和地图绑定首先要将地图坐标点转换出屏幕坐标就好了,设置好事件去联动请求数据。
var dataPoint = new Point(geo.x, geo.y, map.spatialReference);
screenGeometry = map.toScreen(dataPoint);
绑定好数据还要做的就是将热力图的画布元素放入合适位置(整好叠在地图上,尺寸一致),不影响地图本身操作。
var canvas = document.getElementsByTagName('canvas')[0];
var heatmap = createWebGLHeatmap({
canvas: canvas,
intensityToAlpha: true
});
var reforeNode = document.getElementById("map_gc");
document.getElementById("map_layers").insertBefore(heatmap.canvas, reforeNode);
写好了扩展,生成十万的随机数据进行测试,与自带的热力图进行一下对比。自带热力图: 435.635ms;webgl热力图扩展:126.260ms。说明webgl速度更快,同时使用过程不存在地图卡顿,性能提升显著
附完整代码
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=7,IE=9"/>
<!--The viewport meta tag is used to improve the presentation and behavior
of the samples on iOS devices-->
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>heatmap.js ArcGIS JavaScript API Heatmap Layer</title>
<link rel="shortcut icon"
type="image/png" href="http://www.patrick-wied.at/img/favicon.png"/>
<link rel="stylesheet" href="https://js.arcgis.com/3.24/esri/css/esri.css">
<style>
body, html {
margin: 0;
padding: 0;
width: 99.9%;
height: 99.9%;
font-family: Arial;
}
#map {
width: 100%;
height: 100%;
margin: 0;
padding: 0;
border: 0px dashed black;
background-color: rgb(0, 38, 48);
}
</style>
</head>
<body>
<div id="map">
</div>
</body>
<script src="https://js.arcgis.com/3.24/"></script>
<script type="text/javascript" src="heatmap/webgl-heatmap.js"></script>
<script type="text/javascript">
var map;
require([
"esri/map",
"dojo/on",
"dojo/dom",
"esri/layers/ArcGISTiledMapServiceLayer",
"esri/tasks/query",
"esri/tasks/QueryTask",
"esri/geometry/screenUtils",
"esri/geometry/Extent",
"esri/geometry/Point",
"dojo/domReady!"
], function (
Map,
on,
dom,
ArcGISTiledMapServiceLayer,
Query,
QueryTask,
screenUtils,
Extent,
Point
) {
// Variables
var valueField = 'Focal'
// get the features within the current extent from the feature layer
function getFeatures() {
var q = new Query();
var url = 'http://services.arcgis.com/V6ZHFr6zdgNZuVG0/arcgis/rest/services/Earthquakes_Since_1970/FeatureServer/0'
var queryTask = new QueryTask(url);
q.geometry = map.extent;
q.where = "1=1";
q.outFields = [valueField ]
q.orderByFields = [valueField ];
q.returnGeometry = true
q.geometryPrecision = 10;
q.outSpatialReference = map.spatialReference;
queryTask.execute(q, function (re) {
console.log(re.features.length)
if (re.features.length) {
console.time('end')
console.log(re.features)
setdata(re.features);
console.timeEnd('end')
}
});
}
var mapExtent = new Extent({
xmax:22189975.059293926,
xmin: -15302081.56646192,
ymax: 8961447.604325403,
ymin: -9569334.036901515,
spatialReference: {wkid: 102100}
})
map = new Map("map", {
basemap: "gray",
extent: mapExtent,
sliderStyle: "small",
logo: false
});
map.resize();
var canvas = document.createElement('canvas');
canvas.id = "heatLayer";
canvas.style.zIndex = 99
canvas.style.position = "absolute";
canvas.style.width="100%"
canvas.style.height="100%"
var heatmap = createWebGLHeatmap({
canvas: canvas,
//gradientTexture: 'heatmap-gradient2.png',
intensityToAlpha: true
});
var reforeNode = document.getElementById("map_gc");
document.getElementById("map_layers").insertBefore(heatmap.canvas, reforeNode);
var raf = window.requestAnimationFrame || window.mozRequestAnimationFrame ||
window.webkitRequestAnimationFrame || window.msRequestAnimationFrame;
var update = function () {
//heatmap.addPoint(100, 100, 100, 10/255);
heatmap.adjustSize(); // can be commented out for statically sized heatmaps, resize clears the map
heatmap.update(); // adds the buffered points
heatmap.display(); // adds the buffered points
raf(update);
}
raf(update);
//getFeatures()
getFeatures()
map.on('zoom-end', function (e) {
getFeatures()
});
map.on('zoom-start', function (e) {
heatmap.clear();
});
map.on('pan-start', function (e) {
heatmap.clear();
});
map.on('pan-end', getFeatures);
map.on('dragstart', function (e) {
heatmap.clear();
});
map.on('dragend', getFeatures);
map.on('mousewheel', function (e) {
heatmap.clear();
getFeatures()
})
function setdata(features) {
var i, da, m, dataPoint, heatmapdata, attributes, screenGeometry
heatmapdata = []
da = []
for (i = 0; i < features.length; i++) {
da.push();
}
m = features[features.length - 1].attributes[valueField ]
for (i = 0; i < features.length; i++) {
var geo = features[i].geometry.normalize();
dataPoint = new Point(geo.x, geo.y, map.spatialReference);
attributes = features[i].attributes;
var va = attributes[valueField ]
//var normalizedExtent = map.extent._normalize();
screenGeometry = map.toScreen(dataPoint);
//screenUtils.toScreenGeometry(normalizedExtent, map.width, map.height, dataPoint);
if (attributes && attributes.hasOwnProperty(valueField )) {
heatmapdata.push({
x: screenGeometry.x,
y: screenGeometry.y,
size: 30,
intensity: va / m
});
} else {
heatmapdata.push({
x: screenGeometry.x,
y: screenGeometry.y,
size: 30,
intensity: 0
});
}
}
heatmap.clear();
heatmap.addPoints(heatmapdata);
}
});
</script>
</html>
小贴士:开启大数据量绘制需要修改webgl-heatmap.js中的this.maxPointCount值(默认是10240),这样就可以为所欲为了。。。
ArcGIS JS 3.x使用webgl绘制热力图的更多相关文章
- 如何用webgl(three.js)搭建不规则建筑模型,客流量热力图模拟
本节课主要讲解如何用webgl(three.js)搭建一个建筑模型,客流量热力图模拟 使用技术说明: 这里主要用到了three.js,echart.js以及一些其它的js 与css技术,利用webso ...
- 基于ArcGIS JS API的在线专题地图实现
0 引言 专题地图是突出而深入的表示一种或几种要素或现象,即按照地图主题的要求,集中表示与主题有关内容的地图.专题地图的专题要素多种多样,分类方法也多种多样,根据专题地图表现数据的特点可分为定 ...
- ArcGIS JS 学习笔记1 用ArcGIS JS 实现仿百度地图的距离量测和面积量测
一.开篇 在博客注册了三年,今天才决定写第一篇博客,警告自己不要懒!!! 二.关于ArcGIS JS 版本选择 在写这篇博客时ArcGIS JS 4.0正式版已经发布.它和3.x版本的不同是,Map不 ...
- 利用javascript和WebGL绘制地球 【翻译】
利用javascript和WebGL绘制地球 [翻译] 原翻译:利用javascript和WebGL绘制地球 [翻译] 在我们所有已知的HTML5API中,WebGL可能是最有意思的一个,利用这个AP ...
- geoserver图层属性查询及查询结果转换为arcgis js api能使用的格式
一个项目使用了ArcGIS JS API开发GIS展示层,但GIS服务使用了Geoserver,这时加载Geoserver数据和查询数据就和之前完全不一样了,以下介绍下我使用ArcGIS JS API ...
- WebGL 绘制Line的bug(二)
上一篇文章简单介绍了WebGL绘制Line的bug,不少朋友给我发了私信,看来这个问题大家都遇上过哈.今天这篇文章会讲述解决这个问题的work around. 基本思路 上一篇文章结尾简单提了下解决的 ...
- ArcGIS JS 学习笔记3 实现百度风格的BubblePopup
1. 开篇 模仿是最好的学习,这次我们继续山寨百度,通过自定义Infowindow来实现百度风格的BubblePopup 2.准备 2.1 Copy模板 先打开百度地图,按下f12吧BubblePop ...
- ArcGIS JS Demo
最近在用 ArcGIS 写了一个Demo 效果如下: 1. 引用 ArcGIS JS API arcgis_js_api/init.js 2. 引用 样式 arcgis_js_api/js/esri/ ...
- WebGL绘制有端头的线
关于WebGL绘制线原理不明白的小伙伴,可以看看我之前的文章WebGL绘制有宽度的线.这一篇我们主要来介绍端头的绘制,先看效果图. 端头一般被称为lineCap,主要有以下三种形式: butt最简单等 ...
随机推荐
- Python_NAT
sockMiddle_server.py import sys import socket import threading #回复消息,原样返回 def replyMessage(conn): wh ...
- Egg Dropping Puzzle问题的分析
首先,基本问题是这样:You are given two eggs, and access to a 100-storey building. The aim is to find out the h ...
- Unite Beijing 2018 参会简要分享
一. Training Day 主讲人:鲍建运 操作:马瑞 课程包括较为完整的功能,如灯光设置,角色动画控制,Cinemachine,Timeline,AI寻路,以及最新的Post Processin ...
- 一些常用的linux命令(2)
参考:http://www.cnblogs.com/laov/p/3541414.html 系统管理命令 stat 显示指定文件的详细信息,比ls更详细 who ...
- SSM-Spring-05:Spring的bean是单例还是多例,怎么改变?
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- Spring的bean是单例的 它在Spring容器初始化的时候创建对象 可以修改为多例,在此bean节点中添 ...
- sql server 高可用性技术总结
一. 复制Replication(快照.事务.合并) 应用场景: 负载均衡.提供副本读,写操作. 分区将历史数据复制到其它表中. 授权,将数据提供它人使用. 数据合并. 故障转移. 优点: 实现简单 ...
- synchronized(this) 与synchronized(class) 之间的区别
一.概念 synchronized 是 Java 中的关键字,是利用锁的机制来实现同步的. 锁机制有如下两种特性: 互斥性:即在同一时间只允许一个线程持有某个对象锁,通过这种特性来实现多线程中的协调机 ...
- 搭建微信小程序服务
准备域名和证书 任务时间:20min ~ 40min 小程序后台服务需要通过 HTTPS 访问,在实验开始之前,我们要准备域名和 SSL 证书. 域名注册 如果您还没有域名,可以在腾讯云上选购,过程可 ...
- 图解HTTPS建立过程
阅读目录 准备工作(对应图中prepare1234) 发起链接 最后 关于网络安全加密的介绍可以看之前文章: 1. 网络安全——数据的加密与签名,RSA介绍2. Base64编码.MD5.SHA1-S ...
- FPGA学习笔记(二)——FPGA学习路线及开发流程
###### [该随笔部分内容转载自小梅哥] ######### 一.FPGA学习路线 工具使用 -> 语法学习 -> 逻辑设计 -> IP使用 ->接口设计 -& ...