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

Flutter 框架跨平台鸿蒙开发 - 旅行足迹地图

旅行足迹地图应用欢迎加入开源鸿蒙跨平台社区https://openharmonycrossplatform.csdn.net一、项目概述运行效果图1.1 应用简介旅行足迹地图是一款旅行探索类应用核心理念是打造专属旅行地图。通过可视化技术将用户的旅行足迹以地图形式呈现配合照片关联和旅行故事记录让每一次旅行都成为珍贵的数字记忆。旅行不仅是身体的移动更是心灵的探索。本应用将地理信息、视觉记忆、文字叙事三者融合构建一个立体的旅行档案系统。用户可以在地图上标记到访过的地点关联旅行照片撰写旅行故事最终形成独一无二的个人旅行地图。1.2 核心功能功能模块功能描述实现方式足迹地图可视化展示旅行足迹CustomPainter 经纬度映射地点标记在地图上标记到访地点坐标转换 脉冲动画照片墙展示旅行照片集合GridView 照片关联旅行故事记录旅行经历和感悟文字编辑 时间线展示统计数据旅行数据统计分析数据聚合 图表可视化成就系统解锁旅行成就徽章条件判断 徽章展示1.3 旅行类型序号类型Emoji颜色典型场景1城市️#2196F3都市观光、城市漫步2自然️#4CAF50山川湖泊、森林公园3海滩️#FF9800海滨度假、沙滩游玩4古迹️#9C27B0历史遗迹、文化景点5探险️#E91E63户外徒步、野外露营6美食#F44336美食之旅、特色餐饮1.4 评分等级序号等级星级分值颜色1一般⭐1#9E9E9E2还行⭐⭐2#8BC34A3不错⭐⭐⭐3#CDDC394很棒⭐⭐⭐⭐4#FFC1075难忘⭐⭐⭐⭐⭐5#FF98001.5 技术栈技术领域技术选型版本要求开发框架Flutter 3.0.0编程语言Dart 2.17.0设计规范Material Design 3-状态管理setState-动画控制AnimationController-地图绘制CustomPainter-目标平台鸿蒙OS / WebAPI 21二、项目结构lib/ ├── main_travel_footprint.dart # 应用主入口 │ ├── TravelFootprintApp # 根应用组件 │ ├── TravelType # 旅行类型枚举 │ ├── TravelRating # 评分等级枚举 │ ├── TravelFootprint # 旅行足迹模型 │ ├── WorldMapPainter # 世界地图绘制器 │ ├── TypeChartPainter # 类型分布图表 │ └── TravelFootprintHomePage # 主页面三、数据模型3.1 TravelType 枚举enumTravelType{city(城市,️,Color(0xFF2196F3)),nature(自然,️,Color(0xFF4CAF50)),beach(海滩,️,Color(0xFFFF9800)),historical(古迹,️,Color(0xFF9C27B0)),adventure(探险,️,Color(0xFFE91E63)),food(美食,,Color(0xFFF44336));finalStringlabel;finalStringemoji;finalColorcolor;}3.2 TravelRating 枚举enumTravelRating{one(一般,⭐,1,Color(0xFF9E9E9E)),two(还行,⭐⭐,2,Color(0xFF8BC34A)),three(不错,⭐⭐⭐,3,Color(0xFFCDDC39)),four(很棒,⭐⭐⭐⭐,4,Color(0xFFFFC107)),five(难忘,⭐⭐⭐⭐⭐,5,Color(0xFFFF9800));finalStringlabel;finalStringstars;finalint value;finalColorcolor;}3.3 TravelFootprint 模型classTravelFootprint{finalStringid;// 唯一标识finalStringplaceName;// 地点名称finalStringlocation;// 所在地区finaldouble latitude;// 纬度finaldouble longitude;// 经度finalTravelTypetype;// 旅行类型finalTravelRatingrating;// 评分finalStringstory;// 旅行故事finalListStringphotos;// 照片列表finalDateTimevisitDate;// 访问日期finalint days;// 旅行天数finaldouble cost;// 花费金额}四、核心功能实现4.1 世界地图绘制classWorldMapPainterextendsCustomPainter{finalListTravelFootprintfootprints;finaldouble animationValue;finaldouble pulseValue;overridevoidpaint(Canvascanvas,Sizesize){_drawBackground(canvas,size);_drawGridLines(canvas,size);_drawContinents(canvas,size,center);_drawFootprints(canvas,size);}void_drawContinents(Canvascanvas,Sizesize,Offsetcenter){// 使用贝塞尔曲线绘制简化的大陆轮廓// 北美洲、亚洲、非洲、南美洲、澳大利亚}}4.2 经纬度坐标转换double_longitudeToX(double longitude,double width){returnwidth*(longitude180)/360;}double_latitudeToY(double latitude,double height){returnheight*(90-latitude)/180;}4.3 足迹标记绘制void_drawFootprints(Canvascanvas,Sizesize){for(varfootprintinfootprints){finalx_longitudeToX(footprint.longitude,size.width);finaly_latitudeToY(footprint.latitude,size.height);// 绘制脉冲光晕效果finalpulseSize1.0pulseValue*0.3;finalglowPaintPaint()..colorfootprint.type.color.withValues(alpha:0.3)..maskFilterconstMaskFilter.blur(BlurStyle.normal,10);canvas.drawCircle(Offset(x,y),20*pulseSize,glowPaint);// 绘制标记点canvas.drawCircle(Offset(x,y),12,markerPaint);canvas.drawCircle(Offset(x,y),12,borderPaint);}}4.4 类型分布图表classTypeChartPainterextendsCustomPainter{finalMapTravelType,inttypeCount;overridevoidpaint(Canvascanvas,Sizesize){// 绘制环形饼图for(vartypeintypes){finalsweepAngle2*pi*count/total;canvas.drawArc(rect,startAngle,sweepAngle,true,paint);startAnglesweepAngle;}// 绘制中心圆canvas.drawCircle(center,radius*0.35,innerPaint);}}五、界面设计5.1 页面结构页面功能设计要点足迹地图展示世界地图和足迹标记渐变背景 动态标记照片墙展示所有旅行照片九宫格布局 悬浮标签旅行故事展示旅行故事列表卡片式设计 时间信息统计数据展示旅行统计数据数据卡片 图表展示5.2 配色方案元素颜色值用途主色调#00BCD4品牌色、强调色地图背景#E3F2FD → #90CAF9渐变背景大陆颜色#81C784陆地区域海洋颜色#BBDEFB海洋区域5.3 交互设计// 添加足迹弹窗void_showAddFootprintDialog(){showModalBottomSheet(context:context,isScrollControlled:true,builder:(context)_AddFootprintSheet(onAdd:(footprint){setState((){_footprints.add(footprint);});}),);}// 查看足迹详情void_showFootprintDetail(TravelFootprintfootprint){showModalBottomSheet(context:context,isScrollControlled:true,builder:(context)_FootprintDetailSheet(footprint:footprint),);}六、动画效果6.1 地图动画_mapAnimationControllerAnimationController(vsync:this,duration:constDuration(seconds:20),)..repeat();// 持续旋转动画6.2 脉冲动画_pulseControllerAnimationController(vsync:this,duration:constDuration(milliseconds:1500),)..repeat(reverse:true);// 往返脉冲效果6.3 动画应用动画类型效果描述应用场景地图旋转缓慢旋转的世界地图地图背景脉冲光晕足迹标记的呼吸效果地点标记渐变背景多色渐变过渡页面背景七、运行与调试7.1 运行命令# 运行应用flutter run-dharmonyos lib/main_travel_footprint.dart# 代码分析flutter analyze lib/main_travel_footprint.dart# 构建HAP包flutter build hap--targetlib/main_travel_footprint.dart7.2 调试要点调试项检查内容解决方案地图显示大陆轮廓是否正常调整贝塞尔曲线参数坐标转换经纬度映射是否正确验证转换公式动画性能脉冲动画是否流畅调整动画时长八、扩展方向8.1 功能扩展扩展功能实现思路技术要点真实地图集成地图SDK高德/百度地图API照片上传本地图片选择image_picker插件数据持久化本地数据存储SharedPreferences云端同步数据备份恢复云存储服务分享功能生成分享图片截图 社交分享8.2 界面优化优化项优化方案预期效果地图精度使用矢量地图数据更精确的地图显示照片展示支持真实照片上传更真实的旅行记录路线绘制连接相邻足迹点展示旅行路线九、使用场景9.1 个人旅行记录用户可以将每次旅行的足迹记录在地图上形成个人专属的旅行地图。通过照片和故事的关联让旅行记忆更加立体和生动。9.2 旅行规划参考查看自己过去的旅行足迹分析旅行偏好和消费习惯为未来的旅行规划提供数据支持。9.3 社交分享将旅行足迹地图分享给朋友展示自己的旅行经历交流旅行心得和推荐目的地。十、总结旅行足迹地图应用通过地图可视化技术将用户的旅行经历以直观的方式呈现。应用采用Flutter框架开发使用CustomPainter实现世界地图绘制和足迹标记配合动画效果增强视觉体验。核心亮点包括可视化地图使用贝塞尔曲线绘制简化世界地图直观展示旅行足迹脉冲动画足迹标记采用脉冲光晕效果增强视觉吸引力多维记录支持地点、照片、故事、评分等多维度旅行记录数据统计提供旅行天数、花费、评分等数据统计和图表展示成就系统根据旅行数据解锁成就徽章增加趣味性该应用为旅行爱好者提供了一个记录和展示旅行经历的数字平台让每一段旅程都留下独特的印记。

相关文章:

Flutter 框架跨平台鸿蒙开发 - 旅行足迹地图

旅行足迹地图应用欢迎加入开源鸿蒙跨平台社区: https://openharmonycrossplatform.csdn.net 一、项目概述 运行效果图1.1 应用简介 旅行足迹地图是一款旅行探索类应用,核心理念是"打造专属旅行地图"。通过可视化技术,将用户的旅行足…...

OpenClaw本地搜索增强:Qwen3-14b_int4_awq理解模糊文件查询

OpenClaw本地搜索增强:Qwen3-14b_int4_awq理解模糊文件查询 1. 为什么需要智能文件搜索 作为一名长期与大量文档打交道的技术写作者,我经常陷入"记得内容但找不到文件"的困境。系统自带的搜索功能只能基于文件名或简单关键词匹配&#xff0c…...

第7章:支持向量机(SVM)

第7章:支持向量机(SVM) 树模型的决策边界是"轴对齐的阶梯",而 SVM 在说:“我要找那条与两类数据距离最大的分界线——不是随便一条能分开的线,而是最宽的那条街道的中心线。” 这个追求"最大间隔"的执念,催生了 20 世纪最优雅的分类算法之一。 0. 本…...

C# 已经有了IEnumerator为什么还要封装一个IEnumerable呢

一句话回答你的问题:IEnumerator 是让你走的腿,IEnumerable 是保证每次走路都从原点出发的规则。如果没有 IEnumerable,所有的集合遍历都会变成一次性的磁带,读完就废了它们解决的是两个不同层面的问题:1. 状态的独立性…...

使用Typora与PP-DocLayoutV3打造个人知识库:从图片笔记到结构化文档

使用Typora与PP-DocLayoutV3打造个人知识库:从图片笔记到结构化文档 你是不是也有过这样的经历?听讲座、看书或者头脑风暴时,习惯性地在纸上写写画画,或者用手机拍下白板上的内容。这些手写笔记和照片,记录了当时的灵…...

手动指定服务的调用地址

配置项解释 这是Spring Cloud Ribbon的配置代码,作用是手动指定服务的调用地址,属于微服务开发里的客户端负载均衡配置。 我给你逐行拆解: test: # 【服务名称】你要调用的微服务名字叫 testribbon: # 【组件】使用 Ribbon 负…...

2026年小程序兼容性测试工具选型指南:碎片化设备下的测试效率痛点如何破?

小程序兼容性问题带来的体验影响 作为深耕小程序与前端测试五年的从业者,我见过太多因兼容性问题引发的“翻车现场”:微信更新后按钮消失、安卓机型上布局错乱、基础库版本升级导致接口报错,甚至直接闪退。这些问题不仅影响用户体验&#xff…...

OpenClaw环境迁移:千问3.5-9B配置跨设备同步方案

OpenClaw环境迁移:千问3.5-9B配置跨设备同步方案 1. 为什么需要环境迁移 上周我的主力开发机突然硬盘故障,导致所有OpenClaw配置和千问3.5-9B模型参数丢失。这个意外让我意识到:在本地AI工作流中,环境迁移能力不是锦上添花&…...

wan2.1-vae部署方案:CSDN GPU云+自定义域名+HTTPS反向代理配置

wan2.1-vae部署方案:CSDN GPU云自定义域名HTTPS反向代理配置 1. 平台介绍 muse/wan2.1-vae是基于Qwen-Image-2512模型的AI图像生成平台,能够根据中英文提示词生成高质量、高分辨率的图像。这个平台特别适合需要快速生成专业级图像的用户,无…...

DeerFlow进阶教程:集成MCP服务扩展AI助手能力实战

DeerFlow进阶教程:集成MCP服务扩展AI助手能力实战 1. 引言 1.1 为什么需要MCP服务集成 在AI助手领域,单一模型的能力往往难以满足复杂任务需求。DeerFlow作为深度研究助理,通过集成MCP(Multi-Component Platform)服…...

Python位运算符 | ^的实战应用解析

1. 为什么你需要掌握Python位运算符 很多Python初学者第一次看到&、|、^这些符号时,往往会一脸茫然。这些看起来像键盘上随意敲出来的符号,实际上却是Python中非常强大的位运算符。我在刚开始学习Python时也曾经忽略过它们,直到后来在实际…...

PCB设计中特殊元器件布局与热管理实战技巧

1. 特殊元器件PCB布局的核心挑战在PCB设计领域,特殊元器件就像电路板上的"特种部队",它们往往肩负着关键功能却也是最难部署的单元。这类元器件通常具有以下典型特征:非标准封装尺寸(如异形连接器、大功率模块&#xff…...

伏羲模型在能源行业的应用:风电与光伏发电功率预测实战

伏羲模型在能源行业的应用:风电与光伏发电功率预测实战 最近和一位在电网调度中心工作的朋友聊天,他提到一个挺头疼的问题:风电和光伏发电“看天吃饭”的特性,给电网的稳定运行带来了不小的挑战。今天风大太阳好,发电…...

跨技能协作:OpenClaw调度多个Qwen3-32B-Chat镜像实例完成复杂项目

跨技能协作:OpenClaw调度多个Qwen3-32B-Chat镜像实例完成复杂项目 1. 论文写作自动化的技术挑战 去年写硕士论文时,我曾连续三周每天花6小时在文献检索、内容组织和格式调整上。这种重复性工作让我开始思考:能否用AI实现论文写作的自动化流…...

3步快速部署通义千问1.8B对话模型:无需复杂配置

3步快速部署通义千问1.8B对话模型:无需复杂配置 1. 为什么选择通义千问1.8B对话模型 通义千问1.5-1.8B-Chat-GPTQ-Int4是阿里云推出的轻量级对话模型,特别适合资源有限的部署场景。这个版本经过GPTQ-Int4量化后,显存需求大幅降低到仅4GB左右…...

【Unity游戏模板】超休闲爆款背后:沙子流动游戏的核心技术揭秘

一、插件简介 Sand Flow Puzzle 3D 本质上是一套完整的:像素物理模拟系统 关卡生产工具链 数据驱动玩法框架结合官方文档可以看出,它的设计目标非常明确: 快速产出大量关卡(Image Auto Generator)支持运行时编辑&am…...

Android NFC开发实战:从基础到应用场景解析

1. Android NFC技术入门指南 第一次接触NFC开发时,我被这个看似简单却功能强大的技术深深吸引。NFC(近场通信)就像给你的手机装上了"电子触角",只需要轻轻一碰就能完成数据传输。与蓝牙、WiFi相比,NFC的最大…...

探索MuJoCo视觉抓取强化学习:从零开始的智能机器人控制实战指南

探索MuJoCo视觉抓取强化学习:从零开始的智能机器人控制实战指南 【免费下载链接】MuJoCo_RL_UR5 A MuJoCo/Gym environment for robot control using Reinforcement Learning. The task of agents in this environment is pixel-wise prediction of grasp success c…...

福建钳压式声测管:桩基检测利器

钳压式声测管的定义http://jsoc9409b6b.isitestar.vip/ 钳压式声测管是一种用于桩基检测的预埋管件,通过钳压连接方式实现快速安装。其核心功能是在混凝土灌注桩中形成通道,便于超声波检测仪探测桩身完整性。 主要特点 连接方式:采用钳压工…...

Nordic nRF54115 + BLE 蓝牙6.0:物联网多协议互联

在物联网进入“万物在线”阶段后,真正的挑战已经不只是“能不能连上”,而是如何在复杂环境中稳定、低功耗、低延迟地互联。从智能家居到工业传感,从可穿戴设备到边缘网关,设备之间往往要同时面对多种通信协议、不同功耗等级&#…...

2026 安全新边疆:Token 管道中的信任重建与企业级防御

站在 2026 年的技术潮头,我们正目睹一场深刻的范式转移:企业的核心资产正从静态的“数据库记录”演变为动态流转的 Token(词元)。当 AI 智能体(Agent)开始代表人类进行决策、调用权限并处理海量敏感数据时&…...

火灾后的建筑残骸、燃烧痕迹的光学三维扫描测量逆向-激光三维扫描仪

摘要火灾后的建筑残骸形态、燃烧痕迹分布是事故原因追溯、责任认定及灾后重建的核心依据,其现场易破坏、结构不稳定特性对测量技术提出非接触、快速、高精度要求。激光三维扫描仪依托光学三维扫描测量逆向技术,实现建筑残骸结构、燃烧轨迹的数字化复刻与…...

Phi-4-Reasoning-Vision详细步骤:Streamlit宽屏布局CSS定制与响应式优化

Phi-4-Reasoning-Vision详细步骤:Streamlit宽屏布局CSS定制与响应式优化 1. 项目概述 Phi-4-Reasoning-Vision是基于微软Phi-4-reasoning-vision-15B多模态大模型开发的高性能推理工具,专为双卡4090环境优化。该工具严格遵循官方SYSTEM PROMPT规范&…...

OpenClaw+Phi-3-mini-128k-instruct内容处理:从爬虫到发布的自动化流水线

OpenClawPhi-3-mini-128k-instruct内容处理:从爬虫到发布的自动化流水线 1. 为什么需要内容处理自动化 作为一个技术博主,我每天需要处理大量信息:从技术社区抓取最新动态、整理成可读性强的文章、再发布到多个平台。这个过程耗时费力&…...

WiiChuk_compat:高兼容Nunchuk驱动库详解

1. WiiChuk_compat 库概述WiiChuk_compat 是一个专为嵌入式平台设计的开源 Arduino 兼容库,其核心目标是实现对任天堂 Wii 遥控器扩展配件——Nunchuk(常被误拼为 “Numchuck”、“Nunchuck” 或 “Nunchuk”)的高可靠性、宽兼容性 IC 接口驱…...

Youtu-VL-4B-Instruct生产环境:银行柜台业务凭证OCR+合规字段校验流水线

Youtu-VL-4B-Instruct生产环境:银行柜台业务凭证OCR合规字段校验流水线 1. 引言 想象一下,银行柜员每天要处理成百上千张业务凭证——开户申请书、转账单、存款凭条。每一张都需要人工核对姓名、身份证号、金额、日期等关键信息,确保填写规…...

RV3028-C7超低功耗RTC深度解析:UNIX时间戳与温度补偿实现

1. RV3028-C7 实时时钟模块深度技术解析RV-3028-C7 是一款面向超低功耗、高可靠性嵌入式应用的SMT封装实时时钟(RTC)模块。其核心价值不仅在于提供基础的时间保持功能,更在于将高精度时钟源、智能电源管理、非易失性配置存储与事件时间戳能力…...

24-260409 AI 科技日报 (Gemma 4发布一周下载破千万,开源模型生态加速演进)

24-260409 AI 科技日报 (Gemma 4发布一周下载破千万,开源模型生态加速演进) 共收录 28 条资讯 AI模型 Gemma 4开源模型爆火,一周破千万下载 谷歌的Gemma 4刚发布就火得不行,短短一周内就被下载了超过1000万次。这说明开发者对那种既高效又能…...

STM32串口通信实战与优化技巧

1. STM32串口通信基础解析串口通信作为嵌入式系统中最基础也最常用的外设接口之一,几乎出现在所有STM32项目中。我经手的工业控制器项目中,90%以上的设备调试和模块通信都依赖串口实现。不同于教科书上的理论介绍,实际工程中我们需要面对波特…...

AcousticSense AI零基础部署教程:5分钟搭建音乐流派识别工作站

AcousticSense AI零基础部署教程:5分钟搭建音乐流派识别工作站 1. 引言:让AI成为你的音乐鉴赏助手 你是否曾经遇到过这样的情况:手机里存了几百首下载的音乐,却因为缺乏分类而杂乱无章?或者作为音乐爱好者&#xff0…...