You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
188 lines
5.3 KiB
188 lines
5.3 KiB
# MyQrCode 项目文档
|
|
|
|
欢迎来到 MyQrCode 项目文档!这里包含了项目开发过程中的所有重要文档和说明。
|
|
|
|
## 📚 文档索引
|
|
|
|
### 🚀 核心功能文档
|
|
|
|
1. **[相机授权功能实现说明](CAMERA_PERMISSION_README.md)**
|
|
- 完整的相机权限管理功能
|
|
- 权限检查、请求、状态显示和用户引导
|
|
- 多语言支持的权限界面
|
|
|
|
2. **[重构说明文档](REFACTOR_README.md)**
|
|
- ScannerView 代码重构详细说明
|
|
- 组件化拆分和模块化设计
|
|
- 架构优化和代码组织
|
|
|
|
3. **[多语言支持实现说明](README_Multilingual.md)**
|
|
- 中英文双语支持
|
|
- 本地化字符串管理
|
|
- 语言切换功能
|
|
|
|
4. **[日志系统实现说明](README_Logger.md)**
|
|
- 自定义日志系统
|
|
- 多级别日志管理
|
|
- 调试和监控功能
|
|
|
|
5. **[扫描结果跳转详情页功能](SCANNER_TO_QRCODE_DETAIL_README.md)**
|
|
- 扫描结果自动跳转到二维码详情页
|
|
- 自动保存历史记录到 Core Data
|
|
- 智能条码类型识别和解析
|
|
|
|
6. **[HistoryView 导航方式修改说明](HISTORY_VIEW_NAVIGATION_README.md)**
|
|
- 历史记录页面导航方式统一
|
|
- 从 sheet 改为 NavigationLink 的实现
|
|
- 用户体验一致性的提升
|
|
|
|
7. **[HistoryView 删除功能 Bug 修复说明](HISTORY_DELETE_FUNCTION_FIX_README.md)**
|
|
- 删除功能安全性提升
|
|
- 添加删除确认机制
|
|
- 解决删除操作与导航的冲突
|
|
|
|
8. **[HistoryView 过滤器性能优化和动画改进](HISTORY_FILTER_PERFORMANCE_FIX_README.md)**
|
|
- 解决过滤器切换卡顿问题
|
|
- 数据缓存机制优化
|
|
- 添加流畅的动画效果和按压反馈
|
|
|
|
9. **[HistoryView 收藏功能 Bug 修复说明](HISTORY_FAVORITE_FUNCTION_FIX_README.md)**
|
|
- 修复收藏状态不一致问题
|
|
- 优化数据更新机制
|
|
- 提升收藏操作性能
|
|
|
|
### 🔧 问题修复文档
|
|
|
|
1. **[触摸选择点响应问题修复说明](TOUCH_FIX_README.md)**
|
|
- 触摸区域优化
|
|
- 事件处理改进
|
|
- 用户交互体验提升
|
|
|
|
2. **[重新扫描后无法扫描问题修复说明](SCANNING_ISSUE_FIX_README.md)**
|
|
- 会话状态管理修复
|
|
- 扫描重启逻辑优化
|
|
- 错误处理机制
|
|
|
|
3. **[重新扫描按钮修复说明](RESCAN_BUTTON_FIX_README.md)**
|
|
- 按钮位置重新设计
|
|
- 功能失效问题修复
|
|
- 用户体验优化
|
|
|
|
## 📱 项目概述
|
|
|
|
MyQrCode 是一个功能完整的二维码和条形码扫描应用,采用 SwiftUI 和 AVFoundation 技术栈开发。
|
|
|
|
### 🌟 主要特性
|
|
|
|
- **多格式支持**: 支持 QR 码、条形码等多种格式
|
|
- **多码识别**: 同时识别多个条码并允许用户选择
|
|
- **微信风格界面**: 暂停预览和用户选择功能
|
|
- **多样化扫描线**: 5种不同风格的扫描线动画
|
|
- **多语言支持**: 中英文双语界面
|
|
- **权限管理**: 完整的相机权限管理
|
|
- **日志系统**: 详细的调试和监控日志
|
|
|
|
### 🏗️ 技术架构
|
|
|
|
- **UI框架**: SwiftUI
|
|
- **相机功能**: AVFoundation
|
|
- **架构模式**: MVVM
|
|
- **状态管理**: Combine + @Published
|
|
- **本地化**: .lproj 文件
|
|
- **日志**: 自定义 Logger 系统
|
|
|
|
### 📦 项目结构
|
|
|
|
```
|
|
MyQrCode/
|
|
├── MyQrCode/ # 应用主目录
|
|
│ ├── ScannerView.swift # 主扫描视图(重构后)
|
|
│ ├── ContentView.swift # 应用入口视图
|
|
│ ├── Logger.swift # 日志系统
|
|
│ ├── MyQrCodeApp.swift # 应用入口
|
|
│ ├── en.lproj/ # 英文本地化
|
|
│ ├── zh-Hans.lproj/ # 中文本地化
|
|
│ └── Assets.xcassets/ # 应用资源
|
|
├── docs/ # 项目文档
|
|
└── README.md # 项目主文档
|
|
```
|
|
|
|
## 🚦 开发历程
|
|
|
|
### 阶段 1: 基础功能实现
|
|
- 基本的二维码扫描功能
|
|
- SwiftUI 界面搭建
|
|
- AVFoundation 集成
|
|
|
|
### 阶段 2: 功能增强
|
|
- 多码识别和选择
|
|
- 微信风格的用户界面
|
|
- 扫描线动画效果
|
|
|
|
### 阶段 3: 用户体验优化
|
|
- 触摸交互优化
|
|
- 权限管理完善
|
|
- 多语言支持
|
|
|
|
### 阶段 4: 代码质量提升
|
|
- 代码重构和模块化
|
|
- 日志系统集成
|
|
- 问题修复和优化
|
|
|
|
## 🧪 测试指南
|
|
|
|
### 基本功能测试
|
|
1. 单个二维码扫描
|
|
2. 多个二维码识别和选择
|
|
3. 不同格式的条码扫描
|
|
|
|
### 权限测试
|
|
1. 首次安装权限请求
|
|
2. 权限拒绝后的处理
|
|
3. 权限恢复功能
|
|
|
|
### 用户体验测试
|
|
1. 触摸选择响应
|
|
2. 重新扫描功能
|
|
3. 语言切换功能
|
|
|
|
### 兼容性测试
|
|
1. 不同 iOS 版本
|
|
2. 不同设备尺寸
|
|
3. 横竖屏切换
|
|
|
|
## 🛠️ 开发工具和环境
|
|
|
|
- **开发环境**: Xcode 15+
|
|
- **最低iOS版本**: iOS 15.0
|
|
- **开发语言**: Swift 5.9+
|
|
- **UI框架**: SwiftUI
|
|
- **相机框架**: AVFoundation
|
|
- **依赖管理**: Swift Package Manager
|
|
|
|
## 📋 TODO 和未来计划
|
|
|
|
- [ ] 添加扫描历史记录
|
|
- [ ] 支持生成二维码功能
|
|
- [ ] 添加更多扫描线样式
|
|
- [ ] 优化相机性能
|
|
- [ ] 添加扫描音效
|
|
- [ ] 支持批量扫描
|
|
|
|
## 🤝 贡献指南
|
|
|
|
1. 代码规范遵循 Swift 官方指南
|
|
2. 新功能需要添加相应的文档
|
|
3. 重要变更需要更新测试用例
|
|
4. 提交前需要通过所有测试
|
|
|
|
## 📞 联系信息
|
|
|
|
如果您在使用过程中遇到问题,请通过以下方式联系:
|
|
|
|
- 项目仓库: [GitHub Issues]
|
|
- 开发者邮箱: [开发者邮箱]
|
|
|
|
---
|
|
|
|
最后更新: 2025年8月20日 |