仿贝壳地图画圈找房功能实现(高德地图)

仿贝壳地图画圈找房功能实现(高德地图)

前言

在最近租房时,看到贝壳找房上线了一个地图画圈找房的功能,感觉很是新奇。接触地图开发也有很长一段时间了,以前大部分都是基于web pc端开发,所以一般遇到这种圈选,绘制多边形圆形都是直接基于官方API直接修改使用的,对于PC端鼠标操作来说,现有的交互用起来已经很不错了,但是对于H5移动端来说,只能通过手指触摸来模拟鼠标滑动,直接使用现有的API对于移动端交互体验来说并不是特别好。因此,看到了贝壳找房上这一新颖的功能,确实让我眼前一亮。话不多说,直接开搞,自己手动实现一个看看。有需要的小伙伴可以直接查看源码demo:https://gitee.com/fcli/map-edit.git

效果图如下:

实现思路

刚看到这个功能时,脑海里闪过一个想法,点成线、线成面。既然是线,那肯定是由一堆点组成的,那最终的圈选的面,也是由线包围起来的。然后一顿噼里啪啦操作,当我在PC端模拟的时候发现,并没有那么丝滑,这不经让我思考如此丝滑的滑动体验是怎么实现的,难道是通过画板canvas之类的,然后通过获取绘制的圈范围再和地图经纬度重合计算。事实证明,我完全想多了,当我把它放到H5上时,发现操作起来很丝滑,绘制的线段也是平滑的,这让我醍醐灌顶。一顿测试发现PC端监听 mouseMove事件并没有移动端的touchmove事件的触发的那么频繁,像是浏览器有节流之类的操作。

主要代码

地图初始化

首先,我使用vue3脚手架,所以在引入地图时与官方demo不太一样,通过createElement将地图API加载到页面上,并在地图加载完毕后再触发对应的地图操作。


onMounted(() => {//创建了一个回调函数,高德地图加载完毕会调用window.onload = () => {// 所有关于地图的逻辑全部都要写在这个回调里面// 保证高德地图加载完毕myMap.value = new AMap.Map('map', { resizeEnable: true, center: [121.429516, 31.151997], zoom: 13 });drawMap();};// key是申请的值let url = 'https://webapi.amap.com/maps?v=2.0&key=0cc611512938634634bac0969fdef3c1';//创建一个 script dom元素let jsapi = document.createElement('script');//设定script标签属性jsapi.src = url;//将API文件引入页面中,加载完毕以后会调用函数document.head.appendChild(jsapi);
})
监听绘开始制地图

当开始绘制地图时,先将地图固定,即:不可缩放、不可拖动… 同时将之前绘制的图层remove

myMap.value.on('touchstart', () => {myMap.value.setStatus({showIndoorMap: false,dragEnable: false,keyboardEnable: false,doubleClickZoom: false,zoomEnable: false,rotateEnable: false});if (lastPolyLine.value) {myMap.value.remove(lastPolyLine.value)}if (polygonAfterDraw.value) {myMap.value.remove(polygonAfterDraw.value)}lastPolyLine.value = null;polyPointArray.value = [];isMouseDown.value = true;});
监听绘制过程

当开始绘制时,监听touchmove事件,记录每次move触发的点并保存,通过这些点的集合绘制多边形,每次绘制多边形之前清除之前绘制的线段,在视觉上就能看到一条连续的线。

myMap.value.on('touchmove', (e: any) => {if (isMouseDown.value) {const point = [e.lnglat.lng, e.lnglat.lat]polyPointArray.value.push(point);if (lastPolyLine.value) {myMap.value.remove(lastPolyLine.value)}const polyline = new AMap.Polyline({path: polyPointArray.value, //多边形轮廓isOutline: true,strokeColor: "#3366FF",strokeOpacity: 1,strokeWeight: 2,// 折线样式还支持 'dashed'strokeStyle: "solid",// strokeStyle是dashed时有效strokeDasharray: [15, 5],lineJoin: 'round',lineCap: 'round',zIndex: 50,});myMap.value.add([polyline])lastPolyLine.value = polyline;}});
绘制结束

绘制结束,使用线段的点生成一个面的范围,通过这个范围就能获取到范围内的信息了,最后恢复地图正常状态。

document.addEventListener('touchend', () => {if (isMouseDown.value) {// 退出画线状态isMouseDown.value = false;// 添加多边形覆盖物,设置为禁止点击polygonAfterDraw.value = new AMap.Polygon({fillOpacity: 0.5,fillColor: '#7bccc4',strokeOpacity: 1,strokeColor: '#3366FF',strokeWeight: 4,strokeStyle: 'solid',strokeDasharray: [5, 5],//多边形数据path: polyPointArray.value //多边形轮廓});myMap.value.add(polygonAfterDraw.value);if (lastPolyLine.value) {myMap.value.remove(lastPolyLine.value)}myMap.value.setStatus({showIndoorMap: true,dragEnable: true,keyboardEnable: true,doubleClickZoom: true,zoomEnable: true,rotateEnable: true});}});

结语

H5越来越流行,努力提升H5操作体验确实是前端开发者需要去考虑的,像百度、腾讯等其他地图的实现方式也大同小异,有需要的小伙伴可以直接查看源码demo:https://gitee.com/fcli/map-edit.git

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

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

相关文章

嵌入式板级系统设计【课设】

笔记【嵌入式板级系统设计】 前言版权笔记【嵌入式板级系统设计】资料学习面包板焊接注意焊接教程 焊接电路板基础代码GPIO 外部中断 定时中断 三合一串口 综合实验 风扇控制系统下板三合一窗口综合实验 最后 前言 2023-11-20 08:49:57 以下内容源自《【创作模板五】》 仅供学…

基于Java影视明星系统

基于Java影视明星系统 功能需求 1、明星信息管理:系统需要提供明星信息的录入、编辑、查询和删除功能。每个明星的信息应包括姓名、照片、简介、代表作品等。 2、粉丝互动:系统需要提供粉丝与明星互动的功能,如粉丝关注、评论、点赞等。明…

blender的weight paint模式

Blender 的权重绘制模式下的 Draw 、Blur、Average 和 Smear 工具。😊 - Draw 工具可以在网格上绘制指定的权重值。权重值是一个从 0 到 1 的数字,表示顶点对顶点组的影响程度。权重值越高,顶点的颜色越红,权重值越低&#xff0c…

安装you-get(mac)

1、首先要有python环境 2、更新pip python -m pip install --upgrade pip 3、安装you-get pip install you-get;

数据库原理: 笛卡儿积

笛卡儿积(Cartesian Product)是集合论中的一个概念,也在数据库中的查询操作中经常使用。笛卡儿积是指两个集合(或更多集合)之间所有可能的组合。如果有两个集合A和B,它们的笛卡儿积记作A B,表示…

设备状态监测好帮手:无线温振传感器的应用

在现代工业生产中,设备状态监测对于确保设备的正常运行和预防故障至关重要。而无线温振传感器的出现为设备状态监测带来了全新的解决方案。本文将介绍无线温振传感器的工作原理和优势,并探讨其在设备状态监测中的广泛应用。 无线温振传感器是一种能够实时…

2024 年 20 款最佳免费视频转换器软件 [安全快速有效]

最佳视频转换器软件的功能和定价的回顾和比较。从顶级付费和免费在线视频转换器工具列表中选择,可以快速轻松地转换任何视频: 什么是视频转换器? 视频转换工具允许您将视频从一种格式转换为另一种格式。第一个商业上成功的视频格式是 Quad&…

【数据库】基于时间戳的并发访问控制,乐观模式,时间戳替代形式及存在的问题,与封锁模式的对比

使用时间戳的并发控制 ​专栏内容: 手写数据库toadb 本专栏主要介绍如何从零开发,开发的步骤,以及开发过程中的涉及的原理,遇到的问题等,让大家能跟上并且可以一起开发,让每个需要的人成为参与者。 本专栏会…

webworker测试示例

<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Web Worker</title> </head> <body><script type"app/worker" id"worker">//注意必须指定<script>…

虚拟化之Stage2地址翻译

目录 1、第二阶段翻译是什么? 2、VMIDs 3、VMID 与 ASID 的交互 4、属性合并和覆盖

2.求n!

文章目录 前言一、题目描述 二、解题 程序运行代码 前言 本系列为函数编程题&#xff0c;点滴成长&#xff0c;一起逆袭。 一、题目描述 2.求n! 二、解题 程序运行代码 #include<stdio.h> int main(){int i,n,result1;scanf("%d",&n);for(i1;i<n;i…

获取计算机所有com信息,使用Modbus RTU读取数据

1.获取计算机所有com信息 使用serial模块实现 # 列出计算机的COM口 import serial.tools.list_ports all_comports serial.tools.list_ports.comports() for comport in all_comports:print(comport.device, comport.name, comport.description, comport.interface)# COM8 C…

聊一聊Java中的枚举和泛型(两种强大的编程特性)

聊一聊Java中的枚举和泛型&#xff08;两种强大的编程特性&#xff09; 保持热爱&#xff0c;奔赴山海。。。。。。 Java中的枚举 在Java中&#xff0c;枚举&#xff08;Enum&#xff09;是一种特殊的数据类型&#xff0c;用于定义包含固定常量集合的数据类型。枚举类型在Jav…

Win10 安装.NET Framework 3.5 报错0x80240438

环境&#xff1a; Win10专业版 NET Framework 3.5 问题描述&#xff1a; Win10 安装.NET Framework 3.5 报错0x80240438 解决方案&#xff1a; 1.检查自动更新服务是否未开启&#xff0c;开启自动更新失败&#xff0c;用工具开启自动更新,重启电脑&#xff08;未解决&am…

如何使用phpStudy本地快速搭建网站并内网穿透远程访问

文章目录 使用工具1. 本地搭建web网站1.1 下载phpstudy后解压并安装1.2 打开默认站点&#xff0c;测试1.3 下载静态演示站点1.4 打开站点根目录1.5 复制演示站点到站网根目录1.6 在浏览器中&#xff0c;查看演示效果。 2. 将本地web网站发布到公网2.1 安装cpolar内网穿透2.2 映…

C++11——包装器

该篇为lambda表达式的延申&#xff0c;请在熟知lambda表达式的基础上阅读该文章 一文详解C11lambda表达式https://blog.csdn.net/qq_74260823/article/details/134839319?spm1001.2014.3001.5501 包装器的由来 这同样是一个不属于C原始风味的语法 我们在lambda表达式中讲到过…

windows 安装两个mysql

参考链接一 参考链接二 安装第二个mysql 端口号改为3307进入 bin目录管理员身份运行cmd mysqld --defaults-fileC:\\soft\\1mysql-5.7.33-winx64\\my.ini --initialize --console 初始化 data 目录修改密码 修改 my.ini 文件添加 skip-grant-tables 见下启动mysql mysqld -…

了解linux计划任务

本章主要介绍如何创建计划任务 使用 at 创建计划任务 使用 crontab 创建计划任务 有时需要在某个指定的时间执行一个操作&#xff0c;此时就要使用计划任务了。计划任务有两种&#xff1a; 一个是at计划任务&#xff0c;另一个是 crontab计划任务。 下面我们分别来看这两种计…

Python 几个简单的案例

1.1 作业讲解 输入一个数字&#xff0c;求解此数字的所有因子之和&#xff01; 如 6 的因子有 1&#xff0c;2&#xff0c;3&#xff0c;6&#xff0c;所有因子相加 123612 numint( input("请输入一个数字:")) #两个核心逻辑&#xff1a; 因子&#xff0c;求和 s0 fo…

c++实验多态程序设计

运行程序&#xff0c;分析结果。 #include <iostream> using namespace std; class B { public: virtual void f1(double x) { cout<<"B::f1(double)"<<x<<endl; } void f2(double x) { cout<<"B::f2(double)"<<…