当前位置: 首页 > news >正文

第12篇|记忆点点击:从 Marker 聚焦到照片详情面板

这篇围绕地图记忆体验展开,把定位、记录模型、Marker 状态和详情面板放在同一条路径里讲。本篇主题是「记忆点点击:从 Marker 聚焦到照片详情面板」,目标是把源码、效果和工程质量放到同一篇文章里讲透。

本文是 21 天「智能相机开发实战」训练营第 3 天的第 4 篇。

这篇解决什么问题

  • 读懂本篇能力在「双镜记忆相机」中的用户价值。
  • 从源码中定位关键入口,而不是只停留在概念介绍。
  • 把页面效果、状态流转和失败态串成一个可复现的小闭环。

代码来自哪里

  • entry/src/main/ets/pages/Index.ets

本篇优先阅读entry/src/main/ets/pages/Index.ets,下面的片段保留项目中的真实命名,方便你在 DevEco Studio 中直接搜索。

this.mapErrorText = ''; this.showMapControllerIfActive(); this.bindMarkerClickEvent(); await this.primeMapCameraAtUserLocation(); await this.syncMapMarkers(); if (this.hasLiveLocation()) { this.focusMapAtCoordinate(this.currentLatitude, this.currentLongitude, false); } else { void this.refreshCurrentLocation(true); } }; } onPageShow(): void { this.applyActiveSystemBarStyle(); this.prepareScenicAgentEntry(); void this.loadGalleryRecords(); void this.loadVideoManagerRecords(); void this.loadGalleryCloudSyncSession(); void this.registerNearbyShareListeners(); if (this.activeTab === 'map') { void this.refreshCurrentLocation(true); void this.startHoldingHandAwareness(); } else if (this.activeTab === 'camera') { this.scheduleCameraCapabilityPrepare(); } void this.loadVolcengineConfig(); this.showMapControllerIfActive(); } onPageHide(): void { this.clearCameraCapabilityPrepareTimer(); this.unregisterNearbyShareListeners(); this.stopGalleryAntiPeepProtection(); this.hideMapController(); this.normalMovieVideoController.pause(); this.normalMoviePreviewPlaying = false; void this.releaseNormalMoviePreviewMusic(); this.hideCameraCapturePreview(); this.stopLocationAwareness(); this.stopHoldingHandAwareness(); void this.teardownDualPreview(); }

源码拆解

  • 先看入口变量或函数:它决定能力从哪个页面、哪个服务或哪个系统配置开始。
  • 再看状态字段:页面上的按钮、提示、加载态通常不是临时文案,而是这些状态的投影。
  • 最后看结果写回:拍摄、定位、AI、同步或分享能力最终都要回到记录模型、页面刷新或用户反馈。

跑出来是什么效果

结合页面效果,本文重点观察:

  • 点击 Marker 前后截图
  • 选中态状态图
流程串联:页面进入 → 地图控制器就绪 → 记录坐标同步 → Marker/详情联动

从页面效果看,关键不是单点能力,而是让用户动作、源码状态和结果反馈保持一致。

实操步骤

  1. 在 DevEco Studio 打开项目,先搜索本文列出的主文件。
  2. 顺着源码片段中的变量或函数名继续查找调用点。
  3. 在真机上运行到对应页面,观察截图中的成功态是否与源码状态一致。
  4. 主动制造一次失败态,例如拒绝权限、断网、无数据或能力不支持。
  5. 把成功态、失败态、源码片段和页面截图串成完整实操闭环。

工程质量点

  • 地图控制器只在可见 Tab 中工作,减少生命周期错位。
  • 坐标转换、选中状态和详情面板分层处理,避免点击 Marker 后状态互相覆盖。
  • 定位失败时保留可浏览首页,让应用不是一进来就卡死。
  • 源码截图只截关键函数,不截整屏代码,方便读者跟着定位。
  • 效果图和流程路径一一对应,避免只讲原理却看不到用户结果。

质量分自评

维度分值本篇检查点
源码准确度28/30代码片段来自项目文件,变量名和函数名保持原样。
效果可见性23/25页面效果与流程路径能说明从点击到结果的路径。
实操完整度19/20读者能按文章复现一个最小操作闭环。
工程质量13/15覆盖失败态、状态边界或隐私边界中的关键点。
表达清晰度10/10标题、截图说明和源码说明互相对齐。
合计93/100达到训练营发布质量线。

今日作业

  1. 拍摄或导入一条带位置的记录,观察地图 Marker 是否出现。
  2. 点击 Marker 后记录状态字段变化,补充一张前后对比图。
  3. 把定位失败时的默认地图体验写成一段用户提示。

完成作业后,下一篇继续沿着同一条源码路径往下走:先做出效果,再把工程边界讲清楚。

http://www.jsqmd.com/news/907944/

相关文章:

  • 从‘module ‘torch‘ has no attribute‘ 到成功运行GCN:一次完整的PyG环境排错实录
  • 别急着买机器人!用FANUC ROBOGUIDE的Handling Pro模块,零成本搞定涂胶方案验证
  • 保姆级教程:手动搞定Visual C++运行库,彻底解决Wireshark安装失败
  • 从MATLAB到FPGA板卡:手把手教你用COE文件为Xilinx FIR滤波器生成并加载系数
  • Python函数:位置参数与关键字参数的使用
  • Unity游戏开发:如何给Luban导表插件加上懒加载,告别启动卡顿(附完整模板修改教程)
  • 别再只盯着file://了!Gopher协议在SSRF中的高级利用与自动化Payload生成
  • 鸿蒙Flutter实战:放弃sqflite选纯Dart JSON文件存储
  • 从零构建自动驾驶小车:树莓派+CNN+PID控制全流程实践
  • 大语言模型内部机制探查:Patchscopes框架与可解释性实践
  • Java面试技巧全攻略:从简历到现场问答
  • PyTorch训练时遇到‘indices should be on the same device’报错?别慌,5分钟教你定位并修复这个GPU/CPU设备不匹配问题
  • 保姆级教程:用USB Burning Tool给UNT413A盒子刷S905L3A纯净固件(附固件下载)
  • 工业视觉实战:用Halcon measure_pairs精准测量零件卡槽宽度(避坑IntraDistance与InterDistance)
  • Java与Spring框架整合:快速构建企业级应用
  • 告别高延迟!在Unity中低延时接入海康威视摄像头的两种实战方案(UMP vs SDK)
  • Keil C51函数地址优化与模块级定位技术详解
  • 第13篇|景点 POI 叠加:附近推荐如何和照片记忆共存
  • Million-AID数据集长尾分布怎么办?手把手教你用PyTorch实现类别平衡采样
  • 基于Arduino的商用咖啡机自动化改造:从流量计感知到继电器控制
  • 病灶溯源:论波普尔证伪主义作为西方伪科学体系的逻辑毒根
  • 用STM32F103C8T6和PCA9685驱动板,我让12个SG90舵机‘听话’地走起来了(附完整代码)
  • 告别信号死角:手把手解读3GPP R17覆盖增强的三大核心黑科技(PUSCH/TBoMS/DMRS)
  • 别再死记硬背命令了!用华为eNSP模拟器,从零搭建一个高可用企业网(VRRP+MSTP+OSPF实战)
  • AI赋能万尺空间:从感知到决策的智能化转型实践
  • 用C++和Eigen手撸一个MINCO轨迹优化器:从论文复现到避坑实战
  • 避开SCARA机器人工作空间规划的坑:从DH建模到奇异点分析与MATLAB可视化
  • Heroku上快速部署PostGIS:从零构建地理空间数据库实战
  • 从Faster R-CNN到Oriented R-CNN:在DOTA数据集上实战旋转目标检测(附完整训练配置)
  • 用Matlab和Robotics Toolbox搞定SCARA机器人建模:从DH参数到工作空间可视化(附KUKA KR 6 R500 Z200实例代码)