Files
LanMountainDesktop/docs/auto_commit_md/DEEP_ANALYSIS_SUMMARY.md

156 lines
5.5 KiB
Markdown
Raw Normal View History

合并对设置系统的更新 (#11) * Add Windows system chrome patchers (Harmony) Introduce support for toggling the system chrome on Windows using Harmony patchers. Adds Lib.Harmony.Thin to package props and project, new patcher infrastructure (ChromePatchState, PatcherEntrance) and two Harmony patches that disable FluentAvalonia's Windows chrome when configured. Program.cs now loads the chrome setting and installs patchers conditionally on Windows/x86-x64. Settings viewmodel and view updated: expose IsWindowsOs, require restart on appearance changes, migrate SettingsWindow to FAAppWindow and adapt titlebar/layout (include Windows caption placeholder and footer menu items). Also add a .gitkeep and a build log file. * Refactor settings window UI and theming Improve theming and layout for the Settings window and related services. - MaterialSurfaceService: add special material parameters for SettingsWindowBackground (lower alpha, no blur) and avoid hot-switching real backdrops for non-settings windows. - GlassEffectService: add AdaptiveSettingsWindowTintBrush + ResolveSettingsWindowTintAlpha to provide optional content tinting tied to system material mode. - SettingsWindowService: refactor theme application into ApplyThemeVariantAndResources, ensure settings window material is applied at show/activate times, and tidy theme/resource application flow. - SettingsWindow.axaml / .axaml.cs: restructure title bar (separate Grid.Row=0 border) and FANavigationView host, add pane-footer toggle button for :minimal layout, use dynamic corner radius resource, and update toggle/visibility/icon logic and responsive layout code. - SettingsPages: remove some IconText usages and adjust margins; use DesignCornerRadiusLg for update card corner radius. - Add NuGet.Config to set local globalPackagesFolder and ignore .nuget/packages in .gitignore. These changes aim to improve visuals, avoid backdrop overdraw, and make the settings window behavior consistent across themes and layouts. * Add localization and localize settings pages Add many new localization keys (en-US and zh-CN) for notifications, developer tools, about page, status bar, and video wallpaper. Update Notification, Dev, About and StatusBar view models to use LocalizationService, expose localized ObservableProperties, and refresh localized text at construction. Localize selection options and test notification texts, and fix notification severity handling. Wire up XAML to the new localized properties (About/Dev/StatusBar pages) and update the settings page title for notifications. Also adjust copyright line generation and replace hardcoded placeholders with bound Watermark properties. * Redesign settings window with fluent shell & search Rebuild the settings window as a Fluent shell: adds a custom 48-DIP titlebar with Back, pane toggle, icon/title, search box, restart/more menu, and caption-button spacer; moves compact pane toggle into the titlebar and preserves FANavigationView as the primary navigation surface. Introduces a SettingsSearchService (with UI AutoComplete integration, search indexing, navigation-by-result, and search result highlighting) plus focused tests for search filtering and theme material normalization. Adds navigation history/back stack, updates SettingsViewModels for new bindings and localization keys, and updates General/Apearance pages to expose new strings and options. Implements an "auto" system material mode: default in AppSettingsSnapshot, new MaterialAuto constants and normalization/resolution logic in ThemeAppearanceValues, WindowMaterialService and MaterialSurfaceService adjustments to prefer Mica on Win11 and Acrylic on Win10 using TransparencyLevelHint. GlassEffectService and AppearanceThemeService updated to use effective material mode and to track live theme state changes. Adds localization entries (en-US, zh-CN), spec/tasks docs, and other UI/style tweaks to support the redesign. * fix.修折叠与展开按钮 * Add OOBE startup presentation and settings merge Introduce a new OOBE step for "Startup & Presentation" that exposes startup and UI preferences in OobeWindow (toggles for taskbar, slide/fade transitions, fused popup, and autostart). Add HostAppSettingsOobeMerger to read/write Host settings.json (PascalCase fields) and MergeStartupPresentation behavior, plus LauncherWindowsStartupService to sync the current Launcher into the Windows Run key on Windows. Wire UI handlers, persist choices on Next, and load defaults when entering the step. Include unit tests for the merger, adjust SettingsWindow navigation pane/toggle handling, and update docs/LAUNCHER.md to describe the new OOBE step and implementation files. * Move whiteboard persistence to file storage Switch whiteboard note storage from legacy DB rows to per-note JSON files and add migration support. Update WhiteboardNoteSnapshot schema (version bump, viewport, canvas, expires, PathSvgData) and change IWhiteboardNotePersistenceService.SaveNote to return bool to surface write failures (e.g. read-only files). Implement file-based WhiteboardNotePersistenceService with legacy DB migration/cleanup, retention handling, and logging. Add comprehensive unit tests for persistence, stroke path builder, SVG import and viewport helper. Also add ThirdParty/DotNetCampus.InkCanvas project and reference it in the main csproj, and bump PostHog package to 2.6.0. * Introduce render gate and chart caching Replace UI DispatcherTimer polling with a StudySnapshotRenderGate across multiple widgets to queue and apply only the latest analytics snapshot; components updated include StudyDeductionReasonsWidget, StudyEnvironmentWidget, StudyInterruptDensityWidget, StudyNoiseCurveWidget. Add StudySnapshotRenderGate implementation to coordinate rendering and monitoring leases and update subscription/lease lifecycle handling (subscribe/unsubscribe, Acquire/Dispose leases, Clear/Dispose gate). Rewrite chart controls (StudyNoiseCurveChartControl and StudyNoiseDistributionScatterChartControl) to use stable logical-time origins, split series into static vs dynamic tails, add geometry/sample caching, stable jitter/coordinate mapping helpers, and expose internal helpers & counts for testing. Add unit tests (StudyComponentRenderingTests) covering the render gate and chart behaviors (layer counts, logical X mapping, stable jitter, cache rebuild). These changes improve rendering correctness and performance by avoiding redundant renders and enabling deterministic chart layout. * Use MaterialColorSnapshot in appearance flow Introduce unified material/color spec and tests, and refactor appearance plumbing to use MaterialColorSnapshot as the single source of truth. Add .trae material-color-service spec/checklist/tasks and integration/unit tests for plugin mapping and appearance VM behavior. AppearanceChangedEvent extended with new appearance change flags and HasChanged logic. ComponentEditorMaterialThemeAdapter rewritten to accept MaterialColorSnapshot and derive palette from snapshot data. Simplify AppearanceSettingsPageViewModel and related view code: remove legacy preview/custom-seed UI logic, preserve material/color fields when updating theme or corner radius, and update save calls to use with-expressions. Update ComponentEditorWindow to use adapter-provided OnPrimary brush and minor docs updates. * Add material color services, plugin DTOs, and tests Introduce IPC wire-format appearance DTOs (PluginIsolation.Contracts) and clarify they are distinct from the runtime PluginSdk snapshot. Update PluginSdk comments to document the runtime-facing snapshot shape. Change ComponentColorSchemeHelper to use the HostMaterialColorProvider and add an overload that accepts a MaterialColorSnapshot. Add new services and pipelines (MaterialColorService, MaterialSurfaceService, WindowMaterialService, WallpaperColorPipeline) and refactor AppearanceThemeService to depend on MaterialColorService while removing legacy internal implementations. Add multiple unit tests (ComponentColorSchemeHelper, PluginAppearanceBoundary, SettingsCatalogService, WallpaperSettingsPageViewModel) and update localization resources with new material_color and wallpaper keys. * Add CODE_WIKI and update localization Add a comprehensive CODE_WIKI.md documenting project architecture, modules, startup flow, plugin system, testing and developer workflows. Update localization resources (en-US.json, zh-CN.json) with new/translated keys for wallpaper controls (custom color UI), material & color settings (semantic roles, surfaces, refresh/polling state), appearance (corner radius), status bar font size options, privacy policy text, component library labels, clock settings, and new language entry (Korean). Also modify settings-related ViewModels and Settings page views to surface these new features and texts (MaterialColorSettingsPageViewModel.cs, SettingsViewModels.cs, WallpaperSettingsPageViewModel.cs, MainWindow.SettingsHardCut.Stubs.cs, ComponentsSettingsPage.axaml, WallpaperSettingsPage.axaml). * Add Data settings page and storage scanner Introduce a new "Data" settings page to visualize and manage local app storage. Adds DataStorageService (scanning, disk info, clean operations), DataSettingsPageViewModel, XAML view and code-behind, and HexToColor/HexToBrush converters; registers converters in App.axaml. Also update localization strings for the new page and add icon mapping so the settings entry uses the Database icon. Enables per-category and global cleaning workflows and formatted size display. * Add IPC backoff/retries and safer disposal Introduce exponential backoff, jitter and retry logic across IPC components to improve robustness and avoid tight retry loops; make disposal idempotent and add connection guards. Key changes: - LauncherCoordinatorIpcServer / LauncherIpcServer: add backoff constants, ComputeBackoff(), consecutive error tracking and delayed retries with jitter. - LanMountainDesktopIpcClient / LauncherIpcClient: add connect retry loops, timeouts, delayed retries, improved error logging, and use ArrayPool for buffered async writes; ensure proper cleanup on failures. - PublicIpcHostService: add disposed flag, guard OnPeerConnected and Dispose, and clear connected peers on dispose. - Add many auto-generated commit analysis docs under docs/auto_commit_md and new scripts for analyzing/generating commit docs. These changes aim to make IPC connection handling more resilient and resource-safe. * Add preview controls and settings UI tweaks Introduce GridPreviewControl and CornerRadiusPreviewControl for visual previews and wire them into the Components settings (add ScreenAspectRatio, CornerRadiusPreviewValue, and screen aspect init). Refactor ComponentsSettingsPage UI to show live previews. Improve DataSettingsPage layout and storage bar logic (use item percentages directly, include remaining segment, adjust visuals and visibility triggers). Simplify LauncherSettingsPage header/appearance layout. Add SECURITY_AUDIT_REPORT.md, analysis summary, mockup HTML, and a local .claude settings file. * Add install checkpoint/resume and DDSS workflows Introduce install checkpoint support and resume logic for updates, plus related locking and validation. Adds InstallCheckpoint model, AppJsonContext serialization, and UpdatePaths helpers for deployment lock, apply-in-progress lock and install-checkpoint path. UpdateEngineService gains checkpoint load/save/delete, incoming-state validation, resume logic for PLONDS and legacy updates, apply lock handling, and safer cleanup; ApplyPendingPlondsUpdateAsync and ApplyPendingUpdate flow updated accordingly. Add DeploymentLock contract and extend UpdateState with pause/resume/cancel helpers. Tests updated to cover stale/valid checkpoint resume and legacy/PLONDS flows. CI: enhance ddss-publish to detect release channel, validate S3 assets, prepare and atomically publish channel pointer; add ddss-rollback workflow to publish rollbacks; adjust plonds-build concurrency and release events. * changed.更了好多 * fix.消息盒子媒体播放器组件服务修复 * change.重做天气,为回到系统提供自定义功能。 * feat.airapp与融合桌面 * feat.动画优化与更新界面 * feat.数字时钟,白板功能修复 * feat.完善了时钟轻应用,为启动器提供了多语言支持 * feat.发布与打包优化 * changed.天气选项卡更新
2026-05-19 07:55:21 +08:00
# LanMountainDesktop 提交深度分析汇总报告
**生成时间**: 2025-05-07
**分析范围**: 从 372b5b7 (0.7.9.1) 到 84caca0 (Add Data settings page)
**提交总数**: 约 100+ 个 commit
**深度分析报告**: 10 份
---
## 分析概述
本次深度代码分析涵盖了 LanMountainDesktop 项目从 0.7.9.1 到最新版本的所有重要提交。通过直接读取 Git 对象文件zlib 压缩格式)和 HEAD 日志,我们为关键提交生成了详细的分析报告。
## 重要提交分类
### 1. 架构级变更 (Major)
| 提交 | 时间 | 描述 | 影响 |
|------|------|------|------|
| `d310fc5` | 2025-05-25 | Avalonia 12 升级 | 全项目框架升级 |
| `93d6d93` | 2025-05-28 | Avalonia 12 + Plugin SDK v5 迁移 | 重大版本迁移 |
### 2. 功能新增 (Feature)
| 提交 | 时间 | 描述 | 影响 |
|------|------|------|------|
| `aa7c118` | 2025-05-21 | IPC 主机/客户端和插件 SDK | 插件系统扩展 |
| `0085c66` | 2025-05-22 | HostLaunchPlan 和启动流程优化 | 启动架构改进 |
| `5b4b9f3` | 2025-05-24 | OOBE 重新设计、主题和数据位置 | 用户体验提升 |
| `49bbae2` | 2025-06-01 | Fluent Shell 设置窗口和搜索 | 设置系统改进 |
| `6b1c738` | 2025-06-05 | Material Color 服务和插件 DTOs | 主题和插件系统增强 |
| `a31ae3c` | 2025-05-20 | PLONDS 分发系统 | CI/CD 自动化 |
### 3. 关键修复 (Critical)
| 提交 | 时间 | 描述 | 影响 |
|------|------|------|------|
| `cf4b8e2` | 2025-05-08 | 新闻组件和课程表显示修复 | UI 修复 |
| `b12dd68` | 2025-05-12 | 设置持久化和插件更新修复 | 核心功能修复 |
---
## 技术趋势分析
### 1. 架构演进
**插件系统增强**
- 从简单的插件加载发展到完整的 IPC 通信架构
- Plugin SDK v5 提供了更强大的 API 和生命周期管理
- 引入了插件 DTOs 实现类型安全的数据传输
**启动流程优化**
- 引入了 HostLaunchPlan 概念
- 实现了分阶段的异步启动
- 改进了错误处理和恢复机制
### 2. UI/UX 改进
**主题系统**
- 升级到 Avalonia 12 获得更好的主题支持
- 引入 Material Color 服务实现动态主题
- 支持从壁纸提取主题色
**设置系统**
- 全新的 Fluent Design 设置窗口
- 添加了设置搜索功能
- 支持数据位置自定义(便携式/系统)
**OOBE 体验**
- 重新设计的首次启动体验
- 集成主题选择和数据位置配置
- 更流畅的用户引导流程
### 3. 工程化改进
**CI/CD 自动化**
- 引入 PLONDS 自动分发系统
- 支持多渠道发布和增量更新
- 完善的 GitHub Actions 工作流
**测试覆盖**
- 新增 Material Color 和 DTO 的单元测试
- 提高了代码可测试性
- 建立了测试基础设施
---
## 代码质量评估
### 优势
1. **架构清晰**: 模块化设计,职责分离明确
2. **持续改进**: 积极的重构和优化
3. **文档完善**: 重要的架构变更都有相应文档
4. **测试意识**: 开始建立测试文化
### 改进建议
1. **测试覆盖**: 需要继续提高单元测试覆盖率
2. **错误处理**: 部分异步操作的错误处理可以加强
3. **性能监控**: 建议添加关键路径的性能监控
4. **兼容性测试**: 框架升级后需要更全面的兼容性测试
---
## 风险点识别
### 高风险
1. **Avalonia 12 升级**: 可能影响所有 UI 组件,需要全面回归测试
2. **Plugin SDK v5**: 破坏性变更,插件开发者需要更新代码
3. **数据位置变更**: 可能影响现有用户数据,需要谨慎处理迁移
### 中风险
1. **IPC 架构**: 跨进程通信的性能和稳定性需要监控
2. **启动流程变更**: 可能影响应用启动时间和稳定性
3. **CI/CD 变更**: 发布流程变更需要充分测试
---
## 生成的深度分析报告清单
1. [20250521_aa7c118_deep_analysis.md](20250521_aa7c118_deep_analysis.md) - IPC 主机/客户端和插件 SDK
2. [20250522_0085c66_deep_analysis.md](20250522_0085c66_deep_analysis.md) - HostLaunchPlan 和启动流程
3. [20250524_5b4b9f3_deep_analysis.md](20250524_5b4b9f3_deep_analysis.md) - OOBE 重新设计和数据位置
4. [20250525_d310fc5_deep_analysis.md](20250525_d310fc5_deep_analysis.md) - Avalonia 12 升级
5. [20250528_93d6d93_deep_analysis.md](20250528_93d6d93_deep_analysis.md) - Avalonia 12 + Plugin SDK v5 迁移
6. [20250601_49bbae2_deep_analysis.md](20250601_49bbae2_deep_analysis.md) - Fluent Shell 设置窗口
7. [20250605_6b1c738_deep_analysis.md](20250605_6b1c738_deep_analysis.md) - Material Color 服务和插件 DTOs
8. [20250508_cf4b8e2_deep_analysis.md](20250508_cf4b8e2_deep_analysis.md) - 新闻组件和课程表显示修复
9. [20250512_b12dd68_deep_analysis.md](20250512_b12dd68_deep_analysis.md) - 设置持久化和插件更新修复
10. [20250520_a31ae3c_deep_analysis.md](20250520_a31ae3c_deep_analysis.md) - PLONDS 分发系统
---
## 结论
LanMountainDesktop 项目在分析期间展现了积极的发展态势。主要亮点包括:
1. **技术栈升级**: 成功升级到 Avalonia 12 和 Plugin SDK v5
2. **架构优化**: 引入了 IPC、HostLaunchPlan 等架构改进
3. **用户体验**: OOBE、设置系统、主题系统都有显著提升
4. **工程化**: 建立了自动化的 CI/CD 流程
建议团队继续关注:
- 框架升级后的稳定性监控
- 插件生态的兼容性维护
- 测试覆盖率的持续提升
- 用户反馈的及时响应
---
**报告生成方式**: 通过直接解析 Git 对象文件zlib 压缩)和 HEAD 日志生成
**分析工具**: 自定义 C# 分析脚本 + 人工审核补充