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

H.Test.DefaultApplicationBase-默认应用组合

H.Test.DefaultApplicationBase 示例项目学习教程一、概述H.Test.DefaultApplicationBase展示了如何使用 WPF-Control 框架的默认应用组合Default ApplicationBase。这是一个开箱即用的应用模板一键注册所有常用服务和模块。核心价值通过AddApplicationServices()一行代码注册所有默认服务快速搭建功能完整的应用框架。二、项目结构H.Test.DefaultApplicationBase/ ├── App.xaml # 应用入口XAML ├── App.xaml.cs # 应用入口代码 ├── MainWindow.xaml # 主窗口XAML ├── MainWindow.xaml.cs # 主窗口代码 └── H.Test.DefaultApplicationBase.csproj三、核心文件解析3.1 App.xamlApplicationBasex:ClassH.Test.DefaultApplicationBase.Appxmlnshttp://schemas.microsoft.com/winfx/2006/xaml/presentationxmlns:xhttp://schemas.microsoft.com/winfx/2006/xamlxmlns:localclr-namespace:H.Test.DefaultApplicationBaseApplication.ResourcesResourceDictionaryResourceDictionary.MergedDictionaries!-- 注释掉的手动配置因为使用默认组合会自动加载 --!--FontSizeTheme Type{x:Static FontSizeThemeType.Default} / LayoutTheme Type{x:Static LayoutThemeType.Default} / ColorTheme Type{x:Static ColorThemeType.Dark} /--!--DefaultStyle /--/ResourceDictionary.MergedDictionaries/ResourceDictionary/Application.Resources/ApplicationBase关键点继承ApplicationBase资源字典中的配置被注释掉因为默认应用组合会自动加载3.2 App.xaml.cs核心publicpartialclassApp:ApplicationBase{protectedoverridevoidConfigureServices(IServiceCollectionservices){base.ConfigureServices(services);// 一键注册所有默认服务services.AddApplicationServices(x{// 配置模块选项x.UseModulesOptions(x{x.UseAboutOptions(xx.ProductNameTest);x.UseSplashScreenOptions(xx.ProductTTTTT);});// 配置主题选项x.UseThemeModuleOptions(x{x.UseThemeOptions(x{x.FontSizeFontSizeThemeType.Large;});});});}protectedoverridevoidConfigure(IApplicationBuilderapp){base.Configure(app);// 启用应用配置app.UseApplicationOptions();}protectedoverrideWindowCreateMainWindow(StartupEventArgse){returnnewMainWindow();}}三大核心步骤AddApplicationServices- 注册所有默认服务Lambda 配置- 自定义模块和主题选项UseApplicationOptions- 启用应用配置3.3 MainWindow.xamlWindowx:ClassH.Test.DefaultApplicationBase.MainWindowxmlnshttp://schemas.microsoft.com/winfx/2006/xaml/presentationxmlns:xhttp://schemas.microsoft.com/winfx/2006/xamlTitleMainWindowWidth800Height450Style{DynamicResource{x:Static WindowKeys.Default}}DockPanel!-- 顶部菜单 --MenuDockPanel.DockTopMenu.ResourcesStyleBasedOn{StaticResource {x:Static MenuItemKeys.BindCommand}}TargetTypeMenuItem//Menu.ResourcesMenuItemHeader帮助MenuItemCommand{ShowGuideCommand}/MenuItemCommand{ShowAboutCommand}/MenuItemCommand{ShowSettingCommand}/!-- 更多菜单项... --/MenuItem/Menu!-- 主内容区 --TabControlTabControl.ResourcesStyleBasedOn{StaticResource {x:Static ButtonKeys.Command}}TargetTypeButton//TabControl.Resources!-- Messages 标签页 --TabItemHeaderMessagesUniformGridButtonCommand{ShowMessageCommand}/ButtonCommand{ShowWaitCommand}/ButtonCommand{ShowPercentCommand}/ButtonCommand{ShowInfoNoticeMessageCommand Message我是 Info 消息}/ButtonCommand{ShowErrorNoticeMessageCommand Message我是 Error 消息}/ButtonCommand{ShowSuccessNoticeMessageCommand Message我是 Success 消息}/!-- 更多消息按钮... --/UniformGrid/TabItem!-- Modules 标签页 --TabItemHeaderModulesUniformGridButtonCommand{ShowAboutCommand}/ButtonCommand{ShowSettingCommand}/ButtonCommand{ShowFeedbackCommand}/!-- 更多模块按钮... --/UniformGrid/TabItem!-- Services 标签页 --TabItemHeaderServicesUniformGridButtonCommand{ShowLog4netPathCommand}//UniformGrid/TabItem/TabControl/DockPanel/Window四、默认服务详解4.1 AddApplicationServices 注册的服务publicstaticvoidAddApplicationServices(thisIServiceCollectionservices,ActionIDefaultApplicationOptionsoptionsnull){DefaultApplicationOptionsoptnewDefaultApplicationOptions();options?.Invoke(opt);// 1. 注册默认消息服务services.AddDefaultMessages();// 2. 注册默认模块服务services.AddDefaultModuleServices(opt.GetConfigOptionsActionIDefaultModuleOptions());// 3. 注册默认主题服务services.AddDefaultThemeServices(opt.GetConfigOptionsActionIDefaultThemeOptions());// 4. 注册日志服务services.AddLog4net();}4.2 默认消息服务AddDefaultMessages()注册服务功能AdornerDialogMessage对话框消息SnackMessage轻提示消息NoticeMessage通知消息FormMessage表单消息4.3 默认模块服务AddDefaultModuleServices()注册模块功能About关于页面Feedback反馈模块Guide新手引导Help帮助入口Setting设置页面Theme主题切换SplashScreen启动画面Login登录模块4.4 默认主题服务AddDefaultThemeServices()注册功能说明颜色主题浅色、深色、蓝色、紫色等字体大小小、中、大布局主题默认布局五、配置选项详解5.1 模块配置x.UseModulesOptions(x{// 配置关于页面x.UseAboutOptions(xx.ProductNameTest);// 配置启动页x.UseSplashScreenOptions(xx.ProductTTTTT);// 配置其他模块...});5.2 主题配置x.UseThemeModuleOptions(x{x.UseThemeOptions(x{// 设置字体大小x.FontSizeFontSizeThemeType.Large;// 添加颜色主题x.ColorResources.Add(newBlueDarkColorResource());x.ColorResources.Add(newBlueLightColorResource());});});六、命令系统6.1 消息命令命令功能ShowMessageCommand显示对话框ShowWaitCommand显示等待提示ShowPercentCommand显示进度百分比ShowEditCommand显示编辑对话框ShowInfoNoticeMessageCommand显示 Info 通知ShowErrorNoticeMessageCommand显示 Error 通知ShowSuccessNoticeMessageCommand显示 Success 通知ShowWarnNoticeMessageCommand显示 Warn 通知6.2 模块命令命令功能ShowAboutCommand显示关于页面ShowSettingCommand显示设置页面ShowFeedbackCommand显示反馈页面ShowGuideCommand显示新手引导ShowWebSiteCommand打开网站ShowSponsorCommand显示赞助页面6.3 服务命令命令功能ShowLog4netPathCommand显示日志文件路径七、运行项目7.1 步骤1. 打开 Visual Studio 2022 2. 打开解决方案Solution/WPF-Control.sln 3. 在解决方案资源管理器中找到 H.Test.DefaultApplicationBase 项目 4. 右键点击项目 → 设置为启动项目 5. 按 F5 运行7.2 预期效果运行后会看到启动页如果配置了登录页如果配置了主窗口顶部菜单栏包含帮助菜单三个标签页Messages、Modules、Services每个标签页有多个按钮点击可触发相应功能八、实际应用案例8.1 最小化配置publicpartialclassApp:ApplicationBase{protectedoverridevoidConfigureServices(IServiceCollectionservices){base.ConfigureServices(services);// 最简单的一行代码注册所有服务services.AddApplicationServices();}protectedoverridevoidConfigure(IApplicationBuilderapp){base.Configure(app);app.UseApplicationOptions();}protectedoverrideWindowCreateMainWindow(StartupEventArgse){returnnewMainWindow();}}8.2 自定义配置publicpartialclassApp:ApplicationBase{protectedoverridevoidConfigureServices(IServiceCollectionservices){base.ConfigureServices(services);services.AddApplicationServices(x{// 配置产品信息x.UseModulesOptions(opt{opt.UseAboutOptions(o{o.ProductName我的应用;o.Version1.0.0;o.Description这是一个示例应用;});opt.UseSplashScreenOptions(o{o.Product我的产品;o.Company我的公司;o.SleepMicroseconds2000;// 启动页停留 2 秒});});// 配置主题x.UseThemeModuleOptions(opt{opt.UseThemeOptions(o{o.FontSizeFontSizeThemeType.Medium;o.ColorResources.Add(newGrayDarkColorResource());o.ColorResources.Add(newGrayLightColorResource());});});});}protectedoverridevoidConfigure(IApplicationBuilderapp){base.Configure(app);app.UseApplicationOptions();}}8.3 添加自定义服务publicpartialclassApp:ApplicationBase{protectedoverridevoidConfigureServices(IServiceCollectionservices){base.ConfigureServices(services);// 注册默认服务services.AddApplicationServices(x{// 配置选项...});// 添加自定义服务services.AddSingletonIDataService,DataService();services.AddTransientIMainViewModel,MainViewModel();}}九、对比学习9.1 与 H.Test.ApplicationBase 对比特性ApplicationBaseDefaultApplicationBase服务注册手动逐个注册一键批量注册配置复杂度高低灵活性高中等适用场景高度定制快速开发9.2 代码对比ApplicationBaseservices.AddAdornerDialogMessage();services.AddSnackMessage();services.AddSetting();services.AddTheme();services.AddAbout();services.AddHelp();// ... 需要注册很多服务DefaultApplicationBaseservices.AddApplicationServices(x{x.UseModulesOptions(x{x.UseAboutOptions(xx.ProductNameTest);});});十、常见问题10.1 服务未注册问题某些服务获取失败。解决1. 确保调用了 AddApplicationServices() 2. 检查配置选项是否正确 3. 确认 UseApplicationOptions() 已调用10.2 样式不显示问题界面没有应用样式。解决1. 确保 UseApplicationOptions() 已调用 2. 检查是否注释掉了手动资源加载 3. 确认主题服务已注册10.3 命令不执行问题按钮点击后命令不执行。解决1. 确保命令已注册到 IOC 容器 2. 检查命令绑定语法是否正确 3. 确认使用了正确的命令样式十一、总结通过学习H.Test.DefaultApplicationBase您掌握了一键注册AddApplicationServices()注册所有默认服务配置选项通过 Lambda 表达式自定义模块和主题命令系统使用内置命令快速实现功能最佳实践如何平衡灵活性和开发效率关键要点使用AddApplicationServices()简化服务注册通过 Lambda 配置自定义选项使用UseApplicationOptions()启用配置内置命令系统提供快速开发能力适用场景✅ 快速原型开发✅ 标准企业应用✅ 需要快速上线的项目❌ 需要高度定制的场景这是构建 WPF-Control 应用的推荐起点可以在默认基础上逐步添加自定义功能。

相关文章:

H.Test.DefaultApplicationBase-默认应用组合

H.Test.DefaultApplicationBase 示例项目学习教程 一、概述 H.Test.DefaultApplicationBase 展示了如何使用 WPF-Control 框架的默认应用组合(Default ApplicationBase)。这是一个"开箱即用"的应用模板,一键注册所有常用服务和模块…...

压测不只是加并发:我们模拟真实用户行为后,发现了隐藏瓶颈

在性能测试领域,一个根深蒂固的误解是:压测就是使劲加线程数,看系统什么时候崩。很多团队用 JMeter 起 500 个并发,照着接口列表跑一圈,看到 TPS 平稳、响应时间没超过 300ms,就觉得万事大吉。可一旦上线&a…...

GetStoreApp核心功能解析:离线部署Microsoft Store应用的5大优势

GetStoreApp核心功能解析:离线部署Microsoft Store应用的5大优势 【免费下载链接】GetStoreApp 离线下载 Microsoft Store 商店应用 项目地址: https://gitcode.com/gh_mirrors/ge/GetStoreApp GetStoreApp是一款专为Windows用户设计的离线下载工具&#xff…...

5个高效技巧:重新定义你的Chrome书签管理体验

5个高效技巧:重新定义你的Chrome书签管理体验 【免费下载链接】neat-bookmarks A neat bookmarks tree popup extension for Chrome [DISCONTINUED] 项目地址: https://gitcode.com/gh_mirrors/ne/neat-bookmarks 你是否曾花费数分钟在混乱的书签海洋中寻找那…...

为 Node.js 后端服务配置 Taotoken 作为大模型统一网关

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 为 Node.js 后端服务配置 Taotoken 作为大模型统一网关 在构建基于大语言模型的 Node.js 后端服务时,直接对接多个模型…...

CANoe测试效率翻倍:手把手教你用XML Test Module搭建可复用的测试套件

CANoe测试效率翻倍:手把手教你用XML Test Module搭建可复用的测试套件在车载电子系统开发中,测试环节往往占据整个项目周期的40%以上时间。面对频繁的ECU软件迭代和多样化配置需求,传统逐个脚本执行测试的方式已经无法满足敏捷开发的要求。本…...

JavaScript语言精粹第三章解读 | 吃透JS对象核心!告别90%日常开发对象Bug

前言 最近重读《JavaScript语言精粹》,复盘JS对象基础的时候,我真的发现了自己多年的编码陋习。 写了好几年前端,每天都在和对象打交道:接口回参解析、页面状态存储、配置项封装,全是{},看似简单到不值一…...

ThriftPy性能测试与基准对比:Cython加速效果分析

ThriftPy性能测试与基准对比:Cython加速效果分析 【免费下载链接】thriftpy Thriftpy has been deprecated, please migrate to https://github.com/Thriftpy/thriftpy2 项目地址: https://gitcode.com/gh_mirrors/th/thriftpy ThriftPy是一款高效的Python T…...

如何永久备份微信聊天记录:3步完成数据导出的终极指南

如何永久备份微信聊天记录:3步完成数据导出的终极指南 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we/WeCha…...

Neat Bookmarks:重构Chrome书签管理的树状结构解决方案

Neat Bookmarks:重构Chrome书签管理的树状结构解决方案 【免费下载链接】neat-bookmarks A neat bookmarks tree popup extension for Chrome [DISCONTINUED] 项目地址: https://gitcode.com/gh_mirrors/ne/neat-bookmarks 在信息过载的数字化工作环境中&…...

AhMyth混淆技术:Android RAT的APK反编译保护与代码混淆全指南

AhMyth混淆技术:Android RAT的APK反编译保护与代码混淆全指南 【免费下载链接】AhMyth Cross-Platform Android Remote Administration Tool | The only maintained version of AhMyth on github | A revival of the original repository at https://GitHub.com/AhM…...

Windows安卓应用安装终极指南:APK Installer让你的电脑变身安卓平台

Windows安卓应用安装终极指南:APK Installer让你的电脑变身安卓平台 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 还在为无法在Windows电脑上直接安装安卓…...

eqMac终极指南:macOS系统级音频均衡器免费使用教程

eqMac终极指南:macOS系统级音频均衡器免费使用教程 【免费下载链接】eqMac macOS System-wide Audio Equalizer & Volume Mixer 🎧 项目地址: https://gitcode.com/gh_mirrors/eq/eqMac 你是否曾经觉得Mac电脑的音质不够理想?想要…...

Windows安卓应用安装终极指南:5分钟实现跨平台应用自由

Windows安卓应用安装终极指南:5分钟实现跨平台应用自由 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 还在为Windows电脑无法直接安装安卓应用而烦恼吗&am…...

工业级SCADA革命:FUXA零代码可视化平台如何重塑工业监控决策

工业级SCADA革命:FUXA零代码可视化平台如何重塑工业监控决策 【免费下载链接】FUXA Web-based Process Visualization (SCADA/HMI/Dashboard) software 项目地址: https://gitcode.com/gh_mirrors/fu/FUXA 在工业4.0和数字化转型浪潮中,传统SCADA…...

Oracle数据库的DBCA界面创建数据库

一、采用DBCA界面方式创建数据库搜索dbca用管理员去运行疯狂的点下一步采用默认就行到监听这里会出有一些问题出问题了先把Enterprise Manager关掉就行,出问题了能自己找出来就行,一般不建议关掉,我这里直接图方便了这里选择所有账号使用同一…...

3大核心价值:Python通达信数据接口MOOTDX的完整应用指南

3大核心价值:Python通达信数据接口MOOTDX的完整应用指南 【免费下载链接】mootdx 通达信数据读取的一个简便使用封装 项目地址: https://gitcode.com/GitHub_Trending/mo/mootdx MOOTDX作为一款优秀的Python通达信数据接口封装库,为开发者提供了免…...

终极指南:使用MuSiC单细胞反卷积工具解密组织细胞组成

终极指南:使用MuSiC单细胞反卷积工具解密组织细胞组成 【免费下载链接】MuSiC Multi-subject Single Cell Deconvolution 项目地址: https://gitcode.com/gh_mirrors/music2/MuSiC 还在为复杂的组织样本分析而困惑吗?想要从批量RNA测序数据中精确…...

【仅限首批200家认证用户】DeepSeek v3.2.1重复检测私有化部署补丁包(含GPU内存泄漏热修复+增量扫描加速模块)

更多请点击: https://intelliparadigm.com 第一章:DeepSeek代码重复检测 DeepSeek-R1 模型在训练过程中引入了严格的代码去重机制,其核心目标是消除训练语料中语义等价或高度相似的代码片段,从而提升模型对真实编程模式的学习能力…...

机器学习预测关税冲击下的股市波动:随机森林、SVR、kNN与线性回归实战对比

1. 项目概述与核心问题拆解做量化研究的朋友们,尤其是关注宏观事件对市场冲击的,应该都对“黑天鹅”事件不陌生。政策变动,特别是像关税这种直接影响国际贸易成本和公司利润的宏观变量,往往会在短期内引发市场剧烈波动。传统的做法…...

从零开始掌握MuSiC:单细胞RNA测序反卷积的完整指南

从零开始掌握MuSiC:单细胞RNA测序反卷积的完整指南 【免费下载链接】MuSiC Multi-subject Single Cell Deconvolution 项目地址: https://gitcode.com/gh_mirrors/music2/MuSiC 还在为复杂的单细胞数据分析而烦恼吗?想要从批量RNA测序数据中准确识…...

混合物理-ML辐射方案:攻克气候模型中次网格云效应的新范式

1. 项目概述与核心挑战在气候模拟这个庞大的数字沙盘中,地球系统模型(ESM)是我们理解未来气候演变的核心工具。然而,这个沙盘有一个长期存在的“颗粒度”难题:受限于计算资源,模型的水平分辨率通常在100到2…...

3大核心模块+5步实战:用RPFM彻底改变《全面战争》模组开发体验

3大核心模块5步实战:用RPFM彻底改变《全面战争》模组开发体验 【免费下载链接】rpfm Rusted PackFile Manager (RPFM) is a... reimplementation in Rust and Qt6 of PackFile Manager (PFM), one of the best modding tools for Total War Games. 项目地址: http…...

Elsevier-Tracker:5分钟打造您的学术论文审稿进度监控系统

Elsevier-Tracker:5分钟打造您的学术论文审稿进度监控系统 【免费下载链接】Elsevier-Tracker 项目地址: https://gitcode.com/gh_mirrors/el/Elsevier-Tracker 在科研工作者的日常中,论文审稿进度追踪常常成为消耗时间与精力的隐形负担。每天反…...

告别烧录烦恼:用Etcher三步打造完美启动盘的终极指南

告别烧录烦恼:用Etcher三步打造完美启动盘的终极指南 【免费下载链接】etcher Flash OS images to SD cards & USB drives, safely and easily. 项目地址: https://gitcode.com/GitHub_Trending/et/etcher 你是否曾因烧录系统镜像而误删硬盘数据&#xf…...

如何高效使用开源电路仿真工具:CircuitJS1桌面版新手快速入门指南

如何高效使用开源电路仿真工具:CircuitJS1桌面版新手快速入门指南 【免费下载链接】circuitjs1 Standalone (offline) version of the Circuit Simulator with small modifications based on modified NW.js. 项目地址: https://gitcode.com/gh_mirrors/circ/circ…...

BetterJoy终极配置指南:5分钟让Switch手柄在PC上完美运行

BetterJoy终极配置指南:5分钟让Switch手柄在PC上完美运行 【免费下载链接】BetterJoy Allows the Nintendo Switch Pro Controller, Joycons and SNES controller to be used with CEMU, Citra, Dolphin, Yuzu and as generic XInput 项目地址: https://gitcode.c…...

Wand-Enhancer:完全免费解锁WeMod专业版功能的终极指南

Wand-Enhancer:完全免费解锁WeMod专业版功能的终极指南 【免费下载链接】Wand-Enhancer Advanced UX and interoperability extension for Wand (WeMod) app 项目地址: https://gitcode.com/gh_mirrors/we/Wand-Enhancer 还在为WeMod专业版的高昂订阅费用而烦…...

QuickDraw MediaPipe手势识别:无需画笔的手势控制绘画应用

QuickDraw MediaPipe手势识别:无需画笔的手势控制绘画应用 【免费下载链接】QuickDraw Implementation of Quickdraw - an online game developed by Google 项目地址: https://gitcode.com/gh_mirrors/qu/QuickDraw QuickDraw MediaPipe手势识别是一款创新…...

安全多方计算中稀疏矩阵乘法优化:原理、实现与隐私保护应用

1. 项目概述:当稀疏矩阵遇上安全多方计算在机器学习、推荐系统这些我们每天都会接触到的技术背后,数据往往以一种“稀疏”的形式存在。想象一下一个拥有百万用户和十万本书籍的在线书店,每个用户可能只读过其中几十本,那么构建一个…...