华为HarmonyOS地图服务 -- 如何实现地图呈现?-- HarmonyOS自学8

如何使用地图组件MapComponent和MapComponentController呈现地图,效果如下图所示。

  • MapComponent是地图组件,用于在您的页面中放置地图。
  • MapComponentController是地图组件的主要功能入口类,用来操作地图,与地图有关的所有方法从此处接入。它所承载的工作包括:地图类型切换(如标准地图、空地图)、改变地图状态(中心点坐标和缩放级别)、添加点标记(Marker)、绘制几何图形(MapPolyline、MapPolygon、MapCircle)、监听各类事件等。

开发步骤

地图显示

  1. 导入Map Kit相关模块。

    1. import { MapComponent, mapCommon, map } from '@kit.MapKit';
    2. import { AsyncCallback } from '@kit.BasicServicesKit';
  2. 新建地图初始化参数mapOption,设置地图中心点坐标及层级。 通过callback回调的方式获取MapComponentController对象,用来操作地图。

    调用MapComponent组件,传入mapOption和callback参数,初始化地图。

    复制代码
    @Entry
    1. @Component
    2. struct HuaweiMapDemo {
    3. private TAG = "HuaweiMapDemo";
    4. private mapOption?: mapCommon.MapOptions;
    5. private callback?: AsyncCallback<map.MapComponentController>;
    6. private mapController?: map.MapComponentController;
    7. aboutToAppear(): void {
    8. // 地图初始化参数,设置地图中心点坐标及层级
    9. this.mapOption = {
    10. position: {
    11. target: {
    12. latitude: 39.9,
    13. longitude: 116.4
    14. },
    15. zoom: 10
    16. }
    17. };
    18. // 地图初始化的回调
    19. this.callback = async (err, mapController) => {
    20. if (!err) {
    21. // 获取地图的控制器类,用来操作地图
    22. this.mapController = mapController;
    23. this.mapController.on("mapLoad", () => {
    24. console.info(this.TAG, `on-mapLoad`);
    25. });
    26. }
    27. };
    28. }
    29. // 页面每次显示时触发一次,包括路由过程、应用进入前台等场景,仅@Entry装饰的自定义组件生效
    30. onPageShow(): void {
    31. // 绘制地图页面的生命周期onPageShow,将地图切换到前台
    32. if (this.mapController !== undefined) {
    33. this.mapController.show();
    34. }
    35. }
    36. // 页面每次隐藏时触发一次,包括路由过程、应用进入后台等场景,仅@Entry装饰的自定义组件生效。
    37. onPageHide(): void {
    38. // 绘制地图页面的生命周期onPageHide,将地图切换到后台
    39. if (this.mapController !== undefined) {
    40. this.mapController.hide();
    41. }}
    42. build() {
    43. Stack() {
    44. // 调用MapComponent组件初始化地图
    45. MapComponent({ mapOptions: this.mapOption, mapCallback: this.callback }).width('100%').height('100%');
    46. }.height('100%')
    47. }
    48. }
    1. 运行您刚完成的工程就可以在您的APP中看到地图了,运行后的效果如下图所示。 如果没有成功加载地图,请参见无法加载地图

更多细节,参见:华为开发者学堂

相关推荐
特立独行的猫a6 小时前
鸿蒙PC三方库编译libiconv链接报错,解决 libtool 链接参数丢失问题过程总结
harmonyos·交叉编译·libiconv·三方库·鸿蒙pc·libtool
哈__6 小时前
Flutter 开发鸿蒙 PC 第一个应用:窗口创建 + 大屏布局
flutter·华为·harmonyos
特立独行的猫a6 小时前
鸿蒙PC命令行及三方库libiconv移植:鸿蒙PC生态的字符编码基石
harmonyos·交叉编译·libiconv·三方库移植·鸿蒙pc
以太浮标9 小时前
华为eNSP模拟器综合实验之- PPP协议解析及配置案例
运维·网络·华为·信息与通信
不爱学英文的码字机器10 小时前
【鸿蒙PC命令行适配】基于OHOS SDK直接构建xz命令集(xz、xzgrep、xzdiff),完善tar.xz解压能力
华为·harmonyos
特立独行的猫a10 小时前
[鸿蒙PC命令行程序移植实战]:交叉编译移植最新openSSL 4.0.0到鸿蒙PC
华为·harmonyos·移植·openssl·交叉编译·鸿蒙pc
特立独行的猫a12 小时前
[鸿蒙PC命令行适配] 移植Aria2文件下载神器最新版到鸿蒙PC的完整教程 (附可运行程序)
harmonyos·移植·交叉编译·aria2·鸿蒙pc
特立独行的猫a13 小时前
[鸿蒙PC三方库交叉编译] libtool与鸿蒙SDK工具链的冲突解决方案:从glibc污染到参数透传的深度解析
华为·harmonyos·ndk·三方库移植·鸿蒙pc·libtool
哈__13 小时前
Flutter For OpenHarmony 鸿蒙 PC 开发入门:环境搭建 + 工程初始化(附 PC 端专属配置)
flutter·华为·harmonyos
数字化顾问15 小时前
(123页PPT)华为流程体系建设与运营(附下载方式)
大数据·华为