百度地图 JavaScript API GL快速升级 和mapV的使用

一、百度地图 JavaScript API GL快速升级

JavaScript API GL升级指南

在这里插入图片描述
1、在原来的链接中添加type = webgl
2、批量替换页面中的BMap直接替换为BMapGL

二、mapV的使用

MapVGL

mapVGL的效率确实要快很多,一万个点基本实现秒现

1、加载mapvgl.min.js

export const loadMapVgl = () => new Promise((resolve, reject) => {if (!window.mapvgl) {const script: any = document.createElement('script');script.type = 'text/javascript';//script.src = 'https://unpkg.com/mapvgl/dist/mapvgl.min.js';script.src = 'https://unpkg.com/mapvgl@1.0.0-beta.189/dist/mapvgl.min.js';script.onerror = reject;const { head } = document;if (head) {head.appendChild(script);}script.onload = function onload() {if (!this.readyState || this.readyState === 'loaded' || this.readyState === 'complete') {// 初始化自定义的覆盖物resolve(window.mapvgl);}script.onload = null;script.onreadystatechange = null;};script.onreadystatechange = script.onload;} else {resolve(window.mapvgl);}
});

2、添加图层

  initLayer(){console.log("initLayer==");this.iconLayer = new window.mapvgl.IconLayer({enablePicked:true,autoSelect:false,onClick: (pickObject:any) => { // 点击事件console.log('pickObject: ', pickObject);console.log("IconLayer clicked");this.showDataInfo(pickObject.dataItem.properties, "device");},});this.facilitiesLayer = new window.mapvgl.IconLayer({enablePicked:true,autoSelect:false,onClick: (pickObject:any) => { // 点击事件console.log('pickObject: ', pickObject);console.log("FacilitiesLayer clicked");this.showDataInfo(pickObject.dataItem.properties, "facilities");},});this.simpleLineLayer = new window.mapvgl.LineLayer({color: '#727cf5',width:3,// enablePicked:true,// onClick: (pickObject:any) => { // 点击事件//   console.log('pickObject: ', pickObject);//   //this.showDataInfo(pickObject.dataItem.properties, "line");// },});console.log('this.iconLayer: ', this.iconLayer);window.mapvglView.addLayer(this.iconLayer);window.mapvglView.addLayer(this.facilitiesLayer);window.mapvglView.addLayer(this.simpleLineLayer);this.isLoadMap = true;}

3、添加点和线数据

省去部分逻辑代码

  if(key == 'device'){this.iconLayer.setData(this.iconGeometryData);}else if(key == 'facilities'){this.facilitiesLayer.setData(this.facilitiesGeometryData);}else{this.simpleLineLayer.setData(this.lineGeometryData);}

目前遇到的问题:

我使用mapV实现大数据展示,设备地图要显示设备、设施,我添加了2个图层,分别显示设备、设施,设备、设施分别由点击事件,添加图层的顺序为设备、设施。 我点击设施时,能正常执行设施的点击事件,但是也会触发设备图层的点击事件。但是点击设备时,点击事件dataIndex=-1

在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/589551.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JAVAEE之Spring, Spring Boot 和Spring MVC的关系以及区别

1.Spring, Spring Boot 和Spring MVC的关系以及区别 Spring: 简单来说, Spring 是⼀个开发应⽤框架,什么样的框架呢,有这么⼏个标签:轻量级、⼀ 站式、模块化,其⽬的是⽤于简化企业级应⽤程序开发 Spring的主要功能: 管理对象&am…

Typecho自媒体博客Spimes主题 X7.2

主题介绍 spimes主题专为博客、自媒体、资讯类的网站设计开发,自适应兼容手机、平板设备。一款简约新闻自媒体类的 typecho 主题,设计上简约、干净、精致、响应式,后台设置更是强大而且实用的新闻自媒体类主题。 已经更新到7.2,删…

安装qrcode库的方法最终解答!

安装qrcode库,记录留痕。 安装qrcode库需要先安装PIL库,如果你是anaconda的话不需要再次下载。 显示successfully installed qrcode… 则表示安装成功 下面是 安装qrcode库操作,PIL库也是一样的。 第①种打开Anaconda-Prompt 输入命令&am…

蓝桥杯真题:货物摆放

import java.util.ArrayList;public class Main {public static void main(String args[]) {//常规思路/*long num 2021041820210418l;int count 0;for ( long i 1 ; i < num ; i ){for ( long j 1 ; j < num ; j ){for ( long k 1 ; k < num ; k ){if ( i * j *…

zIO: Accelerating IO-Intensive Applications with Transparent Zero-Copy IO——论文泛读

OSDI 2022 Paper 论文阅读笔记整理 问题 零拷贝IO一直是一个长期的性能目标。复制会引入内存和CPU开销&#xff0c;限制IO密集型应用程序的性能。IO数据复制在IO堆栈内、通过其应用程序编程接口&#xff08;API&#xff09;和应用程序内执行。现有工作的重点是开发零拷贝IO A…

[Python学习篇] Python创建项目

新建项目 打开开发工具 PyCharm 选择 New Project 目录结构如下 运行 hello world 选中项目&#xff0c;右键 New -> Python File 进行创建文件 运行项目

从redux的基本概念渐进式理解redux/toolkit的用法

概念 Redux toolkit是帮助提高redux开发效率的一个库 React-redux 是将React和Redux toolkit绑定在一起的一个库 action 是一个对象,里面有一个type属性 action creator是一个函数,这个函数可以返回上面的action对象。 reducer 是一个函数,接受两个参数(initilastate, acti…

基于springboot+vue实现的酒店客房管理系统

作者主页&#xff1a;Java码库 主营内容&#xff1a;SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app等设计与开发。 收藏点赞不迷路 关注作者有好处 文末获取源码 技术选型 【后端】&#xff1a;Java 【框架】&#xff1a;spring…

反射Reflection

1. 反射的出现背景 Java 程序中&#xff0c;所有的对象都有两种类型&#xff1a;编译时类型和运行时类型&#xff0c;而很多时候对象的编译时类型和运行时类型不一致。 例如&#xff1a;某些变量或形参的声明类型是 Object 类型&#xff0c;但是程序却需要调用该对象运行时类型…

Java编程使用CGLIB动态代理介绍与实战演示

文章目录 前言技术积累核心概念主要功能适用场景与JDK动态代理的对比 实战演示定义待代理的目标类实现MethodInterceptor接口使用代理对象 测试结果写在最后 前言 在Java编程中&#xff0c;CGLIB (Code Generation Library) 是一个强大的高性能代码生成库&#xff0c;它通过生…

WebGIS 地铁交通线网 | 图扑数字孪生

数字孪生技术在地铁线网的管理和运维中的应用是一个前沿且迅速发展的领域。随着物联网、大数据、云计算以及人工智能技术的发展&#xff0c;地铁线网数字孪生在智能交通和智慧城市建设中的作用日益凸显。 图扑软件基于 HTML5 的 2D、3D 图形渲染引擎&#xff0c;结合 GIS 地图…

[RK3588-Android12] 调试MIPI-双通道-压缩屏(Video Mode/MIPI Dphy 8Lane/DSC 144HZ)

问题描述 被测屏幕&#xff1a;小米Pad6 分辨率&#xff1a;1800X2880 模式&#xff1a;Video Mode/MIPI Dphy 8Lane/DSC 144HZ PPS: 11 00 00 89 30 80 0B 40 03 84 00 14 01 C2 01 C2 02 00 01 F4 00 20 01 AB 00 06 00 0D 05 7A 06 1A 18 00 10 F0 03 0C 20 00 06 0B 0B 33…