电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

使用vue引入maptalks地圖及聚合效果的實現

瀏覽:138日期:2022-12-11 14:41:55

1、安裝maptalks.js

npm install maptalks --save

2、安裝聚合mapkercluster

npm install maptalks.markercluster

3、vue頁面引入

import * as maptalks from ’maptalks’

import {ClusterLayer} from ’maptalks.markercluster’

4、初始化地圖并添加聚合

mounted() { let that = this //--0--//地圖對象的初始化 this.map = new maptalks.Map(’map’, { center: [109.1748453547,21.4586700546], //中心點標記紅十字,用于開發debug centerCross : false, zoom: 13, minZoom : 10, maxZoom : 18, //縮放級別控件 zoomControl : false, // add zoom control scaleControl : true, // add scale control //鷹眼控件 overviewControl : true, // add overview control //設置瓦片圖層的空間參考spatialReference默認就是3857,googlemap的分辨率 spatialReference : { projection : ’EPSG:3857’ //與map一樣,支持更詳細的設置resolutions,fullExtent等 }, baseLayer: new maptalks.TileLayer(’base’, { // urlTemplate: ’http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png’, //renderer : ’canvas’, // set TileLayer’s renderer to canvas //底圖服務器地址,如下為瓦片地址 urlTemplate: ’http://xxx.xx.xxx.xxx:xxxx/mapdata/tiles/{z}/{x}/{y}.png’, //tileSystem 控制瓦片的x,y以及行列,后兩個是origin原點位置(很重要) tileSystem : [1, 1, -20037508.3427890,-20037508.3427890], // tile system //subdomains: [’a’,’b’,’c’], minZoom : 10, maxZoom : 18 // css filter 濾鏡配置 // cssFilter : ’sepia(60%) invert(95%)’, // attribution: ’© <a rel='external nofollow' target='_blank'>Maptalk for Amap</a> contributors’ }), layers : [ new maptalks.VectorLayer(’v’) ], attribution: {//左下角info content: ’©qmap’ } }) // 拖動范圍限制,黑框控 let extent = new maptalks.Extent(108.8584570000,20.9790840000,110.0569128018,22.1177123207) // var extent = new maptalks.Extent(112.5381688894,26.8876543885,112.5605009244,26.9012691519); // set map’s max extent to map’s extent at zoom 14 this.map.setMaxExtent(extent) this.map.setZoom(this.map.getZoom(), { animation : false }) this.map.getLayer(’v’) .addGeometry( new maptalks.Polygon(extent.toArray(), { symbol : { ’polygonOpacity’: 0, ’lineWidth’: 0 } }) ) // 往地圖上添加點位 this.markInfo()}, methods: { setCenter: function(center) { //標注點平移到某個點 let centerV = maptalks1.CRSTransform.transform(center, ’bd09ll’, ’gcj02’) this.map.animateTo({ zoom: 17, center: centerV }, { duration: 1000 }) }, // 上圖 markInfo: function () { let that = this that.map.removeLayer(that.clusterLayer) let markers = [] //--2--//前端聚合查詢 // data from realworld.50000.1.js //需要引入maptalks.markercluster.js //數據格式[lon,lat,name] // 如:[[21.8129763667, 109.2714296333, '曉港名城4號樓'],[21.8131727667, 109.2710308833, '曉港名城6號樓']] for (let i = 0; i < that.addressPoints.length; i++) { let a = that.addressPoints[i] markers.push(new maptalks.Marker(maptalks1.CRSTransform.transform([a.latitude, a.longitude], ’bd09ll’, ’gcj02’), { ’properties’: { ’name’: a.name, ’onSale’: a.onSale }, symbol : [ { ’markerFile’ : a.onSale ? require(’../../../static/img/on.png’) : require(’../../../static/img/off.png’),//標注點圖標 ’markerWidth’ : 30, ’markerHeight’ : 35 },{ ’textName’ : ’{name}’, ’textSize’ : 12, ’textDy’ : -50, ’textHaloRadius’ : 5, ’textHaloFill’ : a.onSale ? ’#FFB427’ : ’#B9B9B9’, ’textFill’ : ’#fff’ // color } ] } ))//.on(’mousedown’, onClick)) } let clusterLayer = new ClusterLayer(’cluster’, markers, { ’noClusterWithOneMarker’ : true, ’noClusterWithHowMany’: 8,//聚合的最小個數 ’maxClusterZoom’ : 15, //'count' is an internal variable: marker count in the cluster. ’symbol’: { ’markerType’ : ’ellipse’, ’markerFill’ : { property:’count’, type:’interval’, stops: [[0, ’rgb(135, 196, 240)’], [9, ’#1bbc9b’],[50, ’rgb(116, 115, 149)’], [99, ’rgb(216, 115, 149)’]]}, ’markerFillOpacity’ : 0.7, ’markerLineOpacity’ : 1, ’markerLineWidth’ : 3, ’markerLineColor’ : ’#fff’, ’markerWidth’ : { property:’count’, type:’interval’, stops: [[0, 40], [9, 60], [50, 70],[99, 80]] }, ’markerHeight’ : { property:’count’, type:’interval’, stops: [[0, 40], [9, 60], [50, 70],[99, 80]] } }, ’drawClusterText’: true, ’geometryEvents’ : true, ’single’: true }) that.map.addLayer(clusterLayer) that.clusterLayer = clusterLayer function onClick(e) { e.target.setInfoWindow({ ’content’: ’<div class='content-’ + e.target.properties.onSale + ’'>’ + e.target.properties.name + ’</div>’, ’width’ : 150, ’dy’ : 5, ’autoPan’: true, ’custom’: false, ’autoOpenOn’ : ’click’, //set to null if not to open when clicking on marker ’autoCloseOn’ : ’click’ }) } }}

補充知識:vue集成maptalk實現geojson3D渲染

我就廢話不多說了,大家還是直接看代碼吧~

//實例化地圖對象 let map = new maptalks.Map('map',{ center: [13.416935229170008, 52.529564137540376], zoom: 20, dragPitch : true, //allow map to drag rotating, true by default dragRotate : true, //enable map to drag pitching and rotating at the same time, false by default dragRotatePitch : true, baseLayer: new maptalks.TileLayer(’base’, { urlTemplate: ’https://{s}.basemaps.cartocdn.com/light_all/{z}/{x}/{y}.png’, subdomains: [’a’,’b’,’c’,’d’], attribution: ’&copy; <a rel='external nofollow' >OpenStreetMap</a> contributors, &copy; <a rel='external nofollow' >CARTO</a>’ }) });// features to draw//將Buildings中的數據,添加到features中 let features = []; buildings.forEach(function (b) { console.log(b.features); features = features.concat(b.features); });// the ThreeLayer to draw buildings let threeLayer = new ThreeLayer(’t’, { forceRenderOnMoving : true, forceRenderOnRotating : true }); threeLayer.prepareToDraw = function (gl, scene, camera) { let me = this; let light = new THREE.DirectionalLight(0xffffff); light.position.set(0, -10, 10).normalize(); scene.add(light); features.forEach(function (g) { let heightPerLevel = 5; let levels = g.properties.levels || 1; let color = 0x2685a7 let m = new THREE.MeshPhongMaterial({color: color, opacity : 0.7}); //change to back side with THREE <= v0.94 // m.side = THREE.BackSide; let mesh = me.toExtrudeMesh(maptalks.GeoJSON.toGeometry(g), heightPerLevel, m, heightPerLevel); if (Array.isArray(mesh)) { scene.add.apply(scene, mesh); } else { scene.add(mesh); } }); }; threeLayer.addTo(map);

以上這篇使用vue引入maptalks地圖及聚合效果的實現就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 滚珠丝杆升降机_螺旋升降机_丝杠升降机-德迈传动 | 金联宇电缆|广东金联宇电缆厂家_广东金联宇电缆实业有限公司 | 钛板_钛管_钛棒_钛盘管-无锡市盛钛科技有限公司 | 二次元影像仪|二次元测量仪|拉力机|全自动影像测量仪厂家_苏州牧象仪器 | 厚壁钢管-厚壁无缝钢管-小口径厚壁钢管-大口径厚壁钢管 - 聊城宽达钢管有限公司 | MOOG伺服阀维修,ATOS比例流量阀维修,伺服阀维修-上海纽顿液压设备有限公司 | 家庭教育吧-在线家庭教育平台,专注青少年家庭教育 | 袋式过滤器,自清洗过滤器,保安过滤器,篮式过滤器,气体过滤器,全自动过滤器,反冲洗过滤器,管道过滤器,无锡驰业环保科技有限公司 | 医用酒精_84消毒液_碘伏消毒液等医用消毒液-漓峰消毒官网 | 乐泰胶水_loctite_乐泰胶_汉高乐泰授权(中国)总代理-鑫华良供应链 | 煤矿支护网片_矿用勾花菱形网_缝管式_管缝式锚杆-邯郸市永年区志涛工矿配件有限公司 | PCB厂|线路板厂|深圳线路板厂|软硬结合板厂|电路板生产厂家|线路板|深圳电路板厂家|铝基板厂家|深联电路-专业生产PCB研发制造 | 校园气象站_超声波气象站_农业气象站_雨量监测站_风途科技 | YAGEO国巨电容|贴片电阻|电容价格|三星代理商-深圳市巨优电子有限公司 | 高铝轻质保温砖_刚玉莫来石砖厂家_轻质耐火砖价格 | 广西正涛环保工程有限公司【官网】 | 螺杆真空泵_耐腐蚀螺杆真空泵_水环真空泵_真空机组_烟台真空泵-烟台斯凯威真空 | 东莞压铸厂_精密压铸_锌合金压铸_铝合金压铸_压铸件加工_东莞祥宇金属制品 | 昊宇水工|河北昊宇水工机械工程有限公司 | 杭州可当科技有限公司—流量卡_随身WiFi_AI摄像头一站式解决方案 | 北京森语科技有限公司-模型制作专家-展览展示-沙盘模型设计制作-多媒体模型软硬件开发-三维地理信息交互沙盘 | 股票入门基础知识_股票知识_股票投资大师_格雷厄姆网 | 安驭邦官网-双向万能直角铣头,加工中心侧铣头,角度头[厂家直销] 闸阀_截止阀_止回阀「生产厂家」-上海卡比阀门有限公司 | 运动木地板_体育木地板_篮球馆木地板_舞台木地板-实木运动地板厂家 | 铁艺,仿竹,竹节,护栏,围栏,篱笆,栅栏,栏杆,护栏网,网围栏,厂家 - 河北稳重金属丝网制品有限公司 山东太阳能路灯厂家-庭院灯生产厂家-济南晟启灯饰有限公司 | 回收二手冲床_金丰旧冲床回收_协易冲床回收 - 大鑫机械设备 | 水质传感器_水质监测站_雨量监测站_水文监测站-山东水境传感科技有限公司 | 超声波破碎仪-均质乳化机(供应杭州,上海,北京,广州,深圳,成都等地)-上海沪析实业有限公司 | 大流量卧式砂磨机_强力分散机_双行星双动力混合机_同心双轴搅拌机-莱州市龙跃化工机械有限公司 | 自动化生产线-自动化装配线-直流电机自动化生产线-东莞市慧百自动化有限公司 | 数码管_LED贴片灯_LED数码管厂家-无锡市冠卓电子科技有限公司 | 热闷罐-高温罐-钢渣热闷罐-山东鑫泰鑫智能热闷罐厂家 | 扫地车厂家-山西洗地机-太原电动扫地车「大同朔州吕梁晋中忻州长治晋城洗地机」山西锦力环保科技有限公司 | 砖机托板价格|免烧砖托板|空心砖托板厂家_山东宏升砖机托板厂 | 电动葫芦|环链电动葫芦-北京凌鹰名优起重葫芦| 「安徽双凯」自动售货机-无人售货机-成人用品-自动饮料食品零食售货机 | 智成电子深圳tdk一级代理-提供TDK电容电感贴片蜂鸣器磁芯lambda电源代理经销,TDK代理商有哪些TDK一级代理商排名查询。-深圳tdk一级代理 | 台湾Apex减速机_APEX行星减速机_台湾精锐减速机厂家代理【现货】-杭州摩森机电 | 水厂自动化|污水处理中控系统|水利信息化|智慧水务|智慧农业-山东德艾自动化科技有限公司 | 路斯特伺服驱动器维修,伦茨伺服驱动器维修|万骏自动化百科 | 苏州教学设备-化工教学设备-环境工程教学模型|同科教仪 |