news 2026/5/27 23:30:37

第07篇|权限分层策略:相机、定位、生物认证、手势为什么分开申请

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
第07篇|权限分层策略:相机、定位、生物认证、手势为什么分开申请

这篇把用户路径和工程边界放在一起看:用户需要可信提示,代码要守住权限、认证、Uri 和私密数据边界。本篇主题是「权限分层策略:相机、定位、生物认证、手势为什么分开申请」,目标是把源码、效果和工程质量放到同一篇文章里讲透。

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

这篇解决什么问题

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

代码来自哪里

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

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

} } @Entry @Component struct Index { @State private activeTab: string = 'map'; @StorageLink('superImage.windowWidthPx') private windowWidthPx: number = 0; @StorageLink('superImage.windowHeightPx') private windowHeightPx: number = 0; @StorageLink('superImage.safeAreaTopPx') private safeAreaTopPx: number = 0; @StorageLink('superImage.safeAreaBottomPx') private safeAreaBottomPx: number = 0; @StorageLink('superImage.isDarkMode') private isDarkMode: boolean = false; @State private selectedMemoryId: string = ''; @State private locationPermissionReady: boolean = false; @State private preciseLocationReady: boolean = false; @State private locationBusy: boolean = false; @State private currentLocationLabel: string = '定位后显示当前回忆点'; @State private currentLocationStatus: string = '定位后自动刷新附近影像记忆'; @State private locationWatcherActive: boolean = false; @State private awarenessStatusText: string = '回忆位置感知待命'; @State private arrivalRecommendationActive: boolean = false; @State private arrivalRecommendationDistance: string = ''; @State private currentLatitude: number = 30.25113; @State private currentLongitude: number = 120.15515; @State private currentLocationFresh: boolean = false; @State private currentLocationAccuracyMeters: number = Number.POSITIVE_INFINITY; @State private scenicAgentQueryText: string = SCENIC_AGENT_DEFAULT_QUERY; @State private scenicAgentQueryVersion: number = 0; @State private scenicAgentStatusText: string = ''; @State private scenicAgentSupportReady: boolean = true; @State private scenicPoiSpots: Array<ScenicPoiSpot> = []; @State private selectedScenicPoiId: string = ''; @State private scenicPoiSearchBusy: boolean = false; @State private holdingHandSide: HoldingHandSide = 'right'; @State private holdingHandAwarenessStatusText: string = '握姿感应待命'; @State private mapReady: boolean = false; @State private mapErrorText: string = ''; @State private showDetailPanel: boolean = false; @State private cameraPermissionReady: boolean = false; @State private cameraCapabilityChecked: boolean = false; @State private dualCameraSupported: boolean = false; @State private cameraStatusText: string = '拍照准备中'; @State private cameraDeviceCount: number = 0; @State private cameraConcurrentProfileCount: number = 0;

源码拆解

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

跑出来是什么效果

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

  • 权限弹窗/拒绝态截图
  • 权限到页面的映射图
flowchart LR A["用户动作"] --> B["权限/认证检查"] B --> C["业务数据边界"] C --> D["成功或可恢复失败"]

这张流程图可以直接放在文章中间,用来解释「源码做了什么」和「用户看到了什么」之间的关系。截图则尽量截最终页面,不只截调试日志。

实操步骤

  1. 在 DevEco Studio 打开项目,先搜索本文列出的主文件。
  2. 顺着源码片段中的变量或函数名继续查找调用点。
  3. 真机或预览器运行到对应页面,补一张成功态截图。
  4. 主动制造一次失败态,例如拒绝权限、断网、无数据或能力不支持。
  5. 把成功态、失败态、源码片段和流程图组合成完整文章。

工程质量点

  • 先说明用户收益,再触发敏感权限或认证动作。
  • 失败态必须可恢复,不能让用户停在无解释的锁定页面。
  • 私密照片、Uri 和分享入口之间保持明确边界。
  • 源码截图只截关键函数,不截整屏代码,方便读者跟着定位。
  • 效果图和流程图一一对应,避免只讲原理却看不到用户结果。

质量分自评

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

今日作业

  1. 在真机上走一遍成功和失败路径,分别截取页面反馈。
  2. 补一张边界图:哪些数据允许公开,哪些只能留在私密域。
  3. 把文章里的失败态文案改成你自己的产品语言。

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

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/27 23:26:57

专业级虚幻引擎Pak文件可视化分析工具:UnrealPakViewer深度解析

专业级虚幻引擎Pak文件可视化分析工具&#xff1a;UnrealPakViewer深度解析 【免费下载链接】UnrealPakViewer 查看 UE4 Pak 文件的图形化工具&#xff0c;支持 UE4 pak/ucas 文件 项目地址: https://gitcode.com/gh_mirrors/un/UnrealPakViewer UnrealPakViewer是一款专…

作者头像 李华
网站建设 2026/5/27 23:26:56

终极免费金融数据指南:如何用AKShare轻松获取全球股票市场数据

终极免费金融数据指南&#xff1a;如何用AKShare轻松获取全球股票市场数据 【免费下载链接】akshare AKShare is an elegant and simple financial data interface library for Python, built for human beings! 开源财经数据接口库 项目地址: https://gitcode.com/gh_mirror…

作者头像 李华
网站建设 2026/5/27 23:26:55

如何在Windows和Linux上免费获得macOS风格的鼠标指针体验

如何在Windows和Linux上免费获得macOS风格的鼠标指针体验 【免费下载链接】apple_cursor Free & Open source macOS Cursors. 项目地址: https://gitcode.com/gh_mirrors/ap/apple_cursor Apple Cursor是一款免费开源的macOS风格鼠标指针主题&#xff0c;为Windows和…

作者头像 李华
网站建设 2026/5/27 23:26:47

NICFS:基于持久内存与智能网卡的高性能文件系统架构解析

1. 项目概述与核心动机在数据中心和高性能计算领域&#xff0c;我们一直在追求两个看似矛盾的目标&#xff1a;极致的存储I/O性能和极高的CPU利用率。传统的存储架构&#xff0c;无论是基于SSD还是HDD&#xff0c;其I/O延迟和带宽瓶颈常常迫使强大的CPU在等待I/O完成时陷入空闲…

作者头像 李华
网站建设 2026/5/27 23:25:41

【2026最新】AIGC检测报告飙红?5款论文降AI工具与3大手工重构策略

看到检测报告上飙高的红色数字&#xff0c;很多人心里都很没底。现在高校对文章降aigc的要求也在不断加码&#xff0c;为了帮大家解决这个麻烦&#xff0c;我花时间专门做了测试&#xff0c;选出了市面上常见的几款工具。 今天就来详细聊聊怎么降低ai率&#xff0c;在这篇文章…

作者头像 李华