javascript如何寫熱點圖_javascript技巧
在gis中,你如果用js來寫熱點圖 不借助後台怎麼搞,as的話比較容易有相應的類別庫甚至官方都有。而且用js不借助arcgis發布rest服務,(註:熱點圖可以藉助服務的形式發布,arcgis for javascript有相應的api支持的),這個時候就比較麻煩了,首先說明下熱點圖是啥?
熱點圖是以點的形式展示,透過補全週邊變化顏色也會相應的調整漸變,類似於足球某個人的運動範圍那種,我找了下有個heapmap可以實作heapmap.js和heapmap-arcgis.js
因為arcigs for javascript api 是以dojo為基礎寫的,所以載入類別庫方式以下
<script type="text/javascript"> var djConfig = { parseOnLoad: true }; </script> <script src="jslibary/heatmap.js"></script> <script src="jslibary/heatmap-arcgis.js"></script>
寫了工具類別去使用這個類別庫
/** * 管理热点图展示 关闭 这里默认以社区为单位 url可改 热点图需要在主页面加上热点 div层 类似map的div * 这个版本先以一个xml来展示 以后改为json的格式 */ var HeatLayerManager = function() { var map; var heatLayer; var graphicLayer; var polygonTemp; var queryVo= new QueryVO(); var ajaxTool; var locateParameter = new LocateParameter(); var symbolTool; var isMouseInfo = true; //查询社区的url来覆盖 人口信息 var paramBackFun; function renderQuery(queryVo1,polygon,roundFlag,paramBackFun1) { paramBackFun = paramBackFun1; var layerName = queryVo1.layerName; graphicLayer.clear(); var url = locateParameter.getUrl(layerName); if(url != "") { var querytask = new esri.tasks.QueryTask(url); var query = new esri.tasks.Query(); if(layerName != "shi") { query.geometry = polygon; } else { query.where = "FID >= 0" } query.returnGeometry = true; query.outSpatialReference = map.spatialReference; if(roundFlag == "false") { query.spatialRelationship = esri.tasks.Query.SPATIAL_REL_CONTAINS; } query.outFields = ["*"]; querytask.execute(query, handle); } } function handle(idResults) { graphicLayer.clear(); var param = new Object(); param.codearr = []; for (var i = 0, il = idResults.features.length; i < il; i++) { var idResult = idResults.features[i]; var polygon = idResult.geometry; var gra = new esri.Graphic(polygon); var attributes = idResult.attributes; param.codearr[i] = attributes[locateParameter.getCodeName(queryVo.layerName)]; var graattribute = new Object(); graattribute["code"] = attributes[locateParameter.getCodeName(queryVo.layerName)]; gra.setAttributes(graattribute); gra.setSymbol(symbolTool.getSymbol("heat")); graphicLayer.add(gra); } paramBackFun(param); } //查询java后台 组织json参数 function ajaxQuery(param) { param.startDate = queryVo.startDate; param.endDate = queryVo.endDate; param.layerName = queryVo.layerName; param.tjfs = queryVo.tjfs; var str = JSON.stringify(param); //alert("ajaxQuery-param: "+str); //--------------------------------------测试环境用 ajaxTool.getLiuDongData1(str,ajaxBack); //------------------------------------- //--------------------------------------真实环境用 // ajaxTool.getLiuDongData(str,ajaxBack); //------------------------------------- } function ajaxBack(obj,num1) { //组装 map对象便于遍历graphic if('2'==queryVo.tjfs){ alert("时间段"); var arr = obj.codearr; }else{ var arr = obj.codearr; var mapobj = new Object(); for(var i = 0, l = arr.length; i < l; i++) { var arrobj = arr[i]; mapobj[arrobj.CODE] = arrobj; //alert("ajaxBack: "+arrobj.CODE); } //--------------------------------------真实环境用 //var graarr = graphicLayer.graphics; //var dataarr = []; //for(var j = 0, m = graarr.length; j < m; j++) //{ // var gra = graarr[j]; // var codeValue = gra.attributes["code"]; // // 暂时码值转换 // var codeobj; // if("shi"==queryVo.layerName){ // //alert(changeAreaCode(codeValue)); // codeobj = mapobj[changeAreaCode(codeValue)]; // }else{ // codeobj = mapobj[codeValue]; // } // //alert("codeValue: "+codeValue); // if(codeobj!=null){ // var pcount = codeobj.PCOUNT; // var point = gra.geometry.getCentroid(); // var feobj = { // attributes: {count:Number(pcount)}, // geometry: { // spatialReference: map.spatialReference, // type: "point", // x: point.x, // y: point.y // // } // } // dataarr.push(feobj); // } // gra.attributes["codeVaue"] = codeobj; //} //------------------------------------- //--------------------------------------测试环境用 var graarr = graphicLayer.graphics; var dataarr = []; var pcountnum = 0.1; for(var j = 0, m = graarr.length; j < m; j++) { var gra = graarr[j]; var codeValue = gra.attributes["code"]; var codeobj = mapobj["440304008001"]; var pcount = pcountnum; var point = gra.geometry.getCentroid(); var feobj = { attributes: {count:Number(pcount)}, geometry: { spatialReference: map.spatialReference, type: "point", x: point.x, y: point.y } } if(num1 == undefined) { num1 = 0.01 } pcountnum = pcountnum + num1; dataarr.push(feobj); gra.attributes["codeVaue"] = codeobj; } //------------------------------------- heatLayer.setData(dataarr); } } /** * 外界返回鼠标移动查询填充图层 * @returns {*} */ this.getHeatLocateLayer = function() { return graphicLayer; } /** * 外界返回热点图层 * @returns {*} */ this.getHeatlayer = function() { return heatLayer; } /** * 初始化热点图 * @param healayerdiv 主页heatlayer div的id * @param map1 */ this.init = function initHeatLayer(healayerdiv,map1) { map = map1; heatLayer = new HeatmapLayer({ config: { "useLocalMaximum": true, "radius": 40, "gradient": { 0.45: "rgb(000,000,255)", 0.55: "rgb(000,255,255)", 0.65: "rgb(000,255,000)", 0.95: "rgb(255,255,000)", 1.00: "rgb(255,000,000)" } }, "map": map, "domNodeId": healayerdiv, "opacity": 0.85 }); graphicLayer = new esri.layers.GraphicsLayer(); map.addLayer(heatLayer); map.addLayer(graphicLayer); ajaxTool = new AjaxTool(); symbolTool = new SymbolTool(); // map.resize(); } this.ajaxBackFun= function(obj,num1) { ajaxBack(obj,num1); } /** * 根据查询数据渲染热点图 * 现在可能是固定死的xml,下次 转json 可能要有参数 以后定 */ this.addRender = function(queryVo1,polygon) { addRenderFun(queryVo1,polygon,ajaxQuery) } //简化方法类 增加回调 function addRenderFun(queryVo1,polygon,paramBackFun1) { polygonTemp = polygon; queryVo = queryVo1; renderQuery(queryVo,polygon,"false",paramBackFun1); } /** * * @param queryVo1 * @param polygon * @param paramBackFun1 */ this.addRenderCallBack = function(queryVo1,polygon,paramBackFun1) { addRenderFun(queryVo1, polygon, paramBackFun1); } /** * 清除热点图的数据 */ this.clearHeatLayer = function() { heatLayer.clearData(); } function changeAreaCode(code){ var resuCode=""; var areaCode = ["440305","440326","440306","440309","440308", "440304","440303","440327","440317","440307"]; var mapCode = ["440305002","440306007","440306001","440306012","440308001", "440304003","440303005","440307012","440307009","440307006"]; for(i=0;i<areaCode.length;i++){ if(code==mapCode[i]){ resuCode = areaCode[i]; break; } } return resuCode; } }
以上就是為大家分享的如何實現熱點圖的關鍵程式碼,希望對大家的學習有所幫助。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

如何使用WebSocket和JavaScript實現線上語音辨識系統引言:隨著科技的不斷發展,語音辨識技術已成為了人工智慧領域的重要組成部分。而基於WebSocket和JavaScript實現的線上語音辨識系統,具備了低延遲、即時性和跨平台的特點,成為了廣泛應用的解決方案。本文將介紹如何使用WebSocket和JavaScript來實現線上語音辨識系

WebSocket與JavaScript:實現即時監控系統的關鍵技術引言:隨著互聯網技術的快速發展,即時監控系統在各個領域中得到了廣泛的應用。而實現即時監控的關鍵技術之一就是WebSocket與JavaScript的結合使用。本文將介紹WebSocket與JavaScript在即時監控系統中的應用,並給出程式碼範例,詳細解釋其實作原理。一、WebSocket技

如何利用JavaScript和WebSocket實現即時線上點餐系統介紹:隨著網路的普及和技術的進步,越來越多的餐廳開始提供線上點餐服務。為了實現即時線上點餐系統,我們可以利用JavaScript和WebSocket技術。 WebSocket是一種基於TCP協定的全雙工通訊協議,可實現客戶端與伺服器的即時雙向通訊。在即時線上點餐系統中,當使用者選擇菜餚並下訂單

如何使用WebSocket和JavaScript實現線上預約系統在當今數位化的時代,越來越多的業務和服務都需要提供線上預約功能。而實現一個高效、即時的線上預約系統是至關重要的。本文將介紹如何使用WebSocket和JavaScript來實作一個線上預約系統,並提供具體的程式碼範例。一、什麼是WebSocketWebSocket是一種在單一TCP連線上進行全雙工

JavaScript和WebSocket:打造高效的即時天氣預報系統引言:如今,天氣預報的準確性對於日常生活以及決策制定具有重要意義。隨著技術的發展,我們可以透過即時獲取天氣數據來提供更準確可靠的天氣預報。在本文中,我們將學習如何使用JavaScript和WebSocket技術,來建立一個高效的即時天氣預報系統。本文將透過具體的程式碼範例來展示實現的過程。 We

JavaScript教學:如何取得HTTP狀態碼,需要具體程式碼範例前言:在Web開發中,經常會涉及到與伺服器進行資料互動的場景。在與伺服器進行通訊時,我們經常需要取得傳回的HTTP狀態碼來判斷操作是否成功,並根據不同的狀態碼來進行對應的處理。本篇文章將教你如何使用JavaScript來取得HTTP狀態碼,並提供一些實用的程式碼範例。使用XMLHttpRequest

用法:在JavaScript中,insertBefore()方法用於在DOM樹中插入一個新的節點。這個方法需要兩個參數:要插入的新節點和參考節點(即新節點將要插入的位置的節點)。

JavaScript是一種廣泛應用於Web開發的程式語言,而WebSocket則是一種用於即時通訊的網路協定。結合二者的強大功能,我們可以打造一個高效率的即時影像處理系統。本文將介紹如何利用JavaScript和WebSocket來實作這個系統,並提供具體的程式碼範例。首先,我們需要明確指出即時影像處理系統的需求和目標。假設我們有一個攝影機設備,可以擷取即時的影像數
