华为HarmonyOS地图服务 6 - 侦听事件来实现地图交互

本章节包含地图的点击和长按、相机移动(华为地图的移动是通过模拟相机移动的方式实现的)、以及"我的位置"按钮点击等事件侦听。

接口说明

以下是地图侦听事件相关接口,以下功能主要由MapComponentController提供,更多接口及使用方法请参见接口文档

接口名 描述
on(type: 'mapClick', callback: Callback<mapCommon.LatLng>): void 设置地图点击事件侦听器。
on(type: 'mapLongClick', callback: Callback<mapCommon.LatLng>): void 设置地图长按事件侦听器。
on(type: 'cameraMoveStart', callback: Callback<number>): void 设置相机开始移动事件侦听器。
on(type: 'cameraMove', callback: Callback<void>): void 设置相机移动事件侦听器。
on(type: 'cameraIdle', callback: Callback<void>): void 设置相机移动结束事件侦听器。
on(type: 'markerClick' , callback: Callback<Marker>): void 设置marker点击事件侦听器。
on(type: 'myLocationButtonClick', callback: Callback<void>): void 设置我的位置按钮点击事件侦听器。
on(type: 'pointAnnotationClick', callback: Callback<PointAnnotation>): void 设置pointAnnotation点击事件侦听器。

开发步骤

地图点击事件侦听

TypeScript 复制代码
this.mapController.on("mapClick", (position) => {
console.info("mapClick", `on-mapClick position = ${position.longitude}`);
});

地图长按事件侦听

TypeScript 复制代码
this.mapController.on("mapLongClick", (position) => {
console.info("mapLongClick", `on-mapLongClick position = ${position.longitude}`);
});

相机移动侦听

相机移动时(华为地图的移动是通过模拟相机移动的方式实现的),通过设置侦听器,能够对相机移动状态进行侦听。

  • 当相机开始移动时,会回调cameraMoveStart。
TypeScript 复制代码
this.mapController.on("cameraMoveStart", (reason) => {
console.info("cameraMoveStart", `on-cameraMoveStart reason = ${reason}`);
});
  • 当相机移动或用户与触摸屏交互时,会多次调用cameraMove。
TypeScript 复制代码
this.mapController.on("cameraMove", () => {
console.info("cameraMove", `on-cameraMove`);
});
  • 当相机停止移动时,会回调cameraIdle。
TypeScript 复制代码
this.mapController.on("cameraIdle", () => {
console.info("cameraIdle", `on-cameraIdle`);
});

标记点击事件侦听

标记是指在地图的指定位置添加标记以标识位置、商家、建筑等。详情请参见标记

TypeScript 复制代码
this.mapController.on("markerClick", (marker) => {
console.info("markerClick", `markerClick: ${marker.getId()}`);
});

我的位置侦听

TypeScript 复制代码
this.mapController.on("myLocationButtonClick", () => {
console.info("myLocationButtonClick", `myLocationButtonClick`);
});

点注释事件侦听

点注释是指在地图的指定位置添加点注释以标识位置、商家、建筑等,并可以通过信息窗口展示详细信息。

TypeScript 复制代码
this.mapController.on("pointAnnotationClick", (pointAnnotation) => {
console.info("pointAnnotationClick", `pointAnnotationClick: ${pointAnnotation.getId()}`);
});
相关推荐
格林威1 小时前
3D相机视觉检测:环境光太强,结构光点云全是噪点怎么办?
开发语言·人工智能·数码相机·计算机视觉·3d·视觉检测·工业相机
格林威2 小时前
线阵工业相机:线阵图像出现“波浪纹”,是机械振动还是编码器问题?
开发语言·人工智能·数码相机·计算机视觉·视觉检测·工业相机·线阵相机
前端不太难3 小时前
鸿蒙PC和App:都在走向 System
华为·状态模式·harmonyos
格林威3 小时前
工业视觉检测:单样本学习 vs 传统监督学习
人工智能·深度学习·数码相机·学习·计算机视觉·视觉检测·工业相机
maaath3 小时前
【maaath】Flutter for OpenHarmony 闹钟时钟应用开发实战
flutter·华为·harmonyos
格林威4 小时前
工业视觉检测:两大主流异常检测开源框架深度对比(PatchCore vs SPADE)
开发语言·人工智能·深度学习·数码相机·计算机视觉·视觉检测·工业相机
maaath4 小时前
【maaath】Flutter for OpenHarmony 短信管理应用实战
flutter·华为·harmonyos
程序猿追4 小时前
从零打造一个“跳一跳”:在HarmonyOS模拟器上用Canvas复刻经典
华为·harmonyos
@不误正业4 小时前
第13章-开源鸿蒙是否适合做端侧AI操作系统
人工智能·开源·harmonyos
格林威4 小时前
线阵工业相机:如何计算线阵相机的行频(Line Rate)?公式+实例
开发语言·人工智能·数码相机·算法·计算机视觉·工业相机·线阵相机