华为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中看到地图了,运行后的效果如下图所示。 如果没有成功加载地图,请参见无法加载地图

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

相关推荐
╰つ栺尖篴夢ゞ1 小时前
HarmonyOS之多态样式stateStyles的使用
华为·harmonyos·statestyles·多态样式
GLAB-Mary7 小时前
HCIE最优规划路线:如何系统性学习华为认证?
学习·华为·华为认证·hcie·数通
lqj_本人7 小时前
鸿蒙Cordova插件架构与OnsenUI组件适配机制深度解析
华为·架构·harmonyos
猫林老师10 小时前
Flutter for HarmonyOS开发指南(六):测试、调试与质量保障体系
flutter·华为·harmonyos
小Mei数码说15 小时前
华为WATCH 5:连接心与心,让生活更美好
华为·智能手表
爱笑的眼睛1115 小时前
HarmonyOS 应用开发中的内存泄漏检测与修复:深入探索与实践指南
华为·harmonyos
kangyouwei16 小时前
鸿蒙开发:19-本地开发配置bash环境执行hvigorw命令
前端·harmonyos
爱笑的眼睛1116 小时前
HarmonyOS 应用开发:系统权限申请与管理深度解析
华为·harmonyos
DIY机器人工房18 小时前
科普:华为星闪是什么?华为星闪(英文名 NearLink)是国际星闪无线短距通信联盟发布的新型无线短距通信标准技术。
stm32·嵌入式硬件·华为·嵌入式·diy机器人工房·嵌入式面试题
天黑请闭眼19 小时前
华为对象存储:nginx代理临时访问地址后访问报错:Authentication Failed
nginx·华为