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

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

相关推荐
亚历克斯神3 小时前
Flutter for OpenHarmony: Flutter 三方库 mutex 为鸿蒙异步任务提供可靠的临界资源互斥锁(并发安全基石)
android·数据库·安全·flutter·华为·harmonyos
钛态3 小时前
Flutter 三方库 smartstruct 鸿蒙化字段映射适配指南:介入静态预编译引擎扫除视图及数据模型双向强转类型错乱隐患,筑稳如磐石的企业级模型治理防线-适配鸿蒙 HarmonyOS ohos
flutter·华为·harmonyos
键盘鼓手苏苏3 小时前
Flutter 组件 csv2json 适配鸿蒙 HarmonyOS 实战:高性能异构数据转换,构建 CSV 流式解析与全栈式数据映射架构
flutter·harmonyos·鸿蒙·openharmony
雷帝木木3 小时前
Flutter 三方库 hrk_logging 的鸿蒙化适配指南 - 实现标准化分层日志记录、支持多目的地输出与日志分级过滤
flutter·harmonyos·鸿蒙·openharmony·hrk_logging
左手厨刀右手茼蒿3 小时前
Flutter 三方库 dio_compatibility_layer 的鸿蒙化适配指南 - 实现 Dio 跨主版本的平滑迁移、支持遗留拦截器兼容与网络请求架构稳定升级
flutter·harmonyos·鸿蒙·openharmony·dio_compatibility_layer
摘星编程3 小时前
开源力量:GitCode+昇腾NPU 部署Mistral-7B-Instruct-v0.2模型的技术探索与经验总结
华为·开源·huggingface·gitcode·昇腾
雷帝木木3 小时前
Flutter 三方库 hashids2 基于鸿蒙安全内核的深度隐匿映射适配:数字指纹泄露防御层、生成短小精悍唯一不可逆加盐哈希,护航全链路请求 URL 隐私-适配鸿蒙 HarmonyOS ohos
安全·flutter·harmonyos
HwJack205 小时前
HarmonyOS响应式布局与窗口监听:让界面像呼吸般灵动的艺术
ubuntu·华为·harmonyos
王码码20356 小时前
Flutter 组件 inappwebview_cookie_manager 适配 鸿蒙Harmony 实战 - 驾驭核心大 Web 容器缓存隧道、构建金融级政企应用绝对防串号跨域大隔离基座
flutter·harmonyos·鸿蒙·openharmony·inappwebview_cookie_manager
左手厨刀右手茼蒿6 小时前
Flutter 组件 ews 的适配 鸿蒙Harmony 实战 - 驾驭企业级 Exchange Web Services 协议、实现鸿蒙端政企办公同步与高安通讯隔离方案
flutter·harmonyos·鸿蒙·openharmony