Mapbox Android学习笔记(7)事件处理

2024-03-26 11:48

本文主要是介绍Mapbox Android学习笔记(7)事件处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Events

Maps SDK提供了监听map事件的各种方法。SDK提供的大多数侦听器如下所示。但是,您偶尔会在其他概述文档中发现特定于其对应API的其他侦听器。

Map click & long click events

可以通过MapboxMap对象设置Click (tap)事件,并在每次事件发生时调用回调。在这两种情况下,回调函数都提供了用户单击地图位置的 LatLng。要向地图添加onClick侦听器,请在应用程序的代码中插入以下代码片段:

mapboxMap.addOnMapClickListener(new MapboxMap.OnMapClickListener() {@Overridepublic void onMapClick(@NonNull LatLng point) {// 获取用户点击的位置point,并显示String string = String.format(Locale.US, "User clicked at: %s", point.toString())Toast.makeText(MainActivity.this, string, Toast.LENGTH_LONG).show();}
});
Convert from screen pixel

当需要知道屏幕上用户手势发生的对应位置时,可以将LatLng点转换为屏幕像素。MapboxMap对象提供了地图的投影,允许您使用 MapboxMap.getprojection(). toscreenlocation(<LatLng>); 将LatLng坐标转换为屏幕像素。当您拥有以像素为单位的屏幕位置并需要将其转换为相应的 LatLng 对象时,则可以使用相反的方法。

转换LatLng和像素坐标之间的值的一个常见用例是,当您想要查询地图的层或源时,例如,确定用户是否单击了POI。可以在Query map features文档中关于如何做到这一点的信息。(参考学习笔记第9部分)

Camera change events

地图的照相机是俯视地图平面的视图。在几乎所有的情况下,您都将与相机交互来调整地图的初始缩放和目标位置。用户还可以通过在地图上执行手势来操作相机,比如捏缩放、用两根手指移动来倾斜、用一根手指移动来调整位置。

Map SDK提供了一些摄像头更改监听器,可以告诉您任何或特定的摄像头动作。SDK提供了不同的摄像机监听器来确定摄像机的移动是由用户手势、内置API动画还是开发人员控制的移动引起的。下面的代码片段显示了各种可用的摄像机监听:

// 开始移动
mapboxMap.addOnCameraMoveStartedListener(new MapboxMap.OnCameraMoveStartedListener() {private final String[] REASONS = {"REASON_API_GESTURE", "REASON_DEVELOPER_ANIMATION", "REASON_API_ANIMATION"};@Override public void onCameraMoveStarted(int reason) {String string = String.format(Locale.US, "OnCameraMoveStarted: %s", REASONS[reason - 1])Toast.makeText(MainActivity.this, string, Toast.LENGTH_LONG).show();}
});// 移动中
mapboxMap.addOnCameraMoveListener(new MapboxMap.OnCameraMoveListener() {@Overridepublic void onCameraMove() {Toast.makeText(MainActivity.this, "onCameraMove", Toast.LENGTH_LONG).show();}
});// 停止移动
mapboxMap.addOnCameraMoveCancelListener(new MapboxMap.OnCameraMoveCanceledListener() {@Overridepublic void onCameraMoveCanceled() {Toast.makeText(MainActivity.this, "onCameraMoveCanceled", Toast.LENGTH_LONG).show();}
});// 相机闲置
mapboxMap.addOnCameraIdleListener(new MapboxMap.OnCameraIdleListener() {@Overridepublic void onCameraIdle() {Toast.makeText(MainActivity.this, "onCameraIdle", Toast.LENGTH_LONG).show();}
});
On fling & on move events

除了摄像头改变监听器外,MapboxMap对象还允许您在用户移动或抛出地图时监听。当用户在屏幕上拖动一根手指,导致相机位置发生变化时,就会发生移动事件。来自用户的类似操作将导致调用 onFling 回调,但是用户将以更大的动力执行该手势。当用户执行特定手势时,只会触发其中一个事件。

mapboxMap.addOnMoveListener(new MapboxMap.OnMoveListener() {@Overridepublic void onMoveBegin(MoveGestureDetector detector) {// user started moving the map}@Overridepublic void onMove(MoveGestureDetector detector) {// user is moving the map}@Overridepublic void onMoveEnd(MoveGestureDetector detector) {// user stopped moving the map}
});mapboxMap.addOnFlingListener(new MapboxMap.OnFlingListener() {@Overridepublic void onFling() {Toast.makeText(MainActivity.this, "onFling", Toast.LENGTH_LONG).show();}
});
Marker and info window events

Maps SDK提供了一个方便的侦听器,用于在用户点击标记时捕获。默认情况下,所有标记都带有一个 onMarkerClick 事件监听器,用于显示和隐藏信息窗口。您可以覆盖这个默认事件监听器,并使用 setOnMarkerClickListener 方法设置您自己的事件监听器。

要显示带有单击标记标题的toast消息,请使用 setOnMarkerClickListener 侦听单击事件,最后调用 toast.maketext()。要避免同时显示toast消息和信息窗口,请在末尾返回true:

mapboxMap.setOnMarkerClickListener(new MapboxMap.OnMarkerClickListener() {@Overridepublic boolean onMarkerClick(@NonNull Marker marker) {Toast.makeText(MainActivity.this, marker.getTitle(), Toast.LENGTH_LONG).show();return true;}
});

在类似的情况下,info窗口提供了几个侦听器,用于在信息窗口单击、长时间单击或用户关闭窗口时收到通知。

// 长时间单击
mapboxMap.setOnInfoWindowLongClickListener(OnInfoWindowLongClickListener);// 关闭窗口
mapboxMap.setOnInfoWindowCloseListener(new MapboxMap.OnInfoWindowCloseListener() {@Overridepublic void onInfoWindowClose(@NonNull Marker marker) {}
});// 单击
mapboxMap.setOnInfoWindowClickListener(new MapboxMap.OnInfoWindowClickListener() {@Overridepublic boolean onInfoWindowClick(@NonNull Marker marker) {return false;}
});
Map change events

MapView在构建和更改地图时经历一系列生命周期事件。Maps SDK提供了许多不同的change listener接口,用于告诉您何时发生了特定的map事件。

不是将侦听器添加到MapboxMap对象,而是将每个侦听器添加到MapView对象。例如OnDidFinishRenderingMapListener和addOnDidFinishLoadingMapListener。

mapView.addOnDidFinishRenderingMapListener(new MapView.OnDidFinishRenderingMapListener() {@Overridepublic void onDidFinishRenderingMap(boolean fully) {// The map has finished rendering	    }
});

您还可以实现特定的变更事件接口并覆盖其方法。然后,当发生新的地图更改时调用接口回调。下面列出的监听器按事件在MapView生命周期中发生的顺序排列,详细参考。任何地图更改事件接口也可以从MapView对象中删除。

如果要使用运行时样式实时更改Mapbox地图样式,addOnDidFinishLoadingStyleListener()非常有用。下面是如何使用这个常数:

mapView.addOnDidFinishLoadingStyleListener(new MapView.OnDidFinishLoadingStyleListener() {@Overridepublic void onDidFinishLoadingStyle() {// The map is now ready for other changes}
});

这篇关于Mapbox Android学习笔记(7)事件处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/848405

相关文章

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Android里面的Service种类以及启动方式

《Android里面的Service种类以及启动方式》Android中的Service分为前台服务和后台服务,前台服务需要亮身份牌并显示通知,后台服务则有启动方式选择,包括startService和b... 目录一句话总结:一、Service 的两种类型:1. 前台服务(必须亮身份牌)2. 后台服务(偷偷干

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤

JavaScript DOM操作与事件处理方法

《JavaScriptDOM操作与事件处理方法》本文通过一系列代码片段,详细介绍了如何使用JavaScript进行DOM操作、事件处理、属性操作、内容操作、尺寸和位置获取,以及实现简单的动画效果,涵... 目录前言1. 类名操作代码片段代码解析2. 属性操作代码片段代码解析3. 内容操作代码片段代码解析4.

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

Android WebView的加载超时处理方案

《AndroidWebView的加载超时处理方案》在Android开发中,WebView是一个常用的组件,用于在应用中嵌入网页,然而,当网络状况不佳或页面加载过慢时,用户可能会遇到加载超时的问题,本... 目录引言一、WebView加载超时的原因二、加载超时处理方案1. 使用Handler和Timer进行超

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06