使用DotNetBar制作漂亮的WinFrom界面,自定义AgileEAS.NET SOA平台WinClient主界面

简介:

一、前言

     AgileEAS.NET SOA 中间件平台是一款基于基于敏捷并行开发思想和Microsoft .Net构件(组件)开发技术而构建的一个快速开发应用平台。用于帮助中小型软件企业建立一条适合市场快速变化的开发团队,以达到节省开发成本、缩短开发时间,快速适应市场变化的目的。

     AgileEAS.NET SOA中间件平台提供了敏捷快速开发软件工程的最佳实践,通过提供大量的基础支撑功能如IOC、ORM、SOA、分布式体系及敏捷并发开发方法所支撑的插件开发体系,以及提供了大量的实体、数据模型设计生成工具、代码生成工具,用于帮助中小软件开发商快速成长。

     AgileEAS.NET平台充分把握目前软件行业快速发展的新趋势,基于敏捷并行开发、快速适应市场这样淳朴的软件工程实践,采用业界广泛使用的Microsoft .Net构件(组件)开发技术实践了这种开发思想,帮助软件企业实现“敏捷变化、快速适合”的目标,从而帮助软件企业在激烈的市场竞争中赢得先机并获得更高的回报。

二、关于WinClient的外挂资源体系介绍

     最初版本的AgileEAS.NET SOA中间件平台的运行容器/外壳是没有界面替换体系,最初只是提供了替换关键部分的图片、文字的功能,随着AgileEAS.NET SOA中间件被众多的客户应用到各行各业之后,我们从客户的应用反馈之中进行了大量的重构,其中运行容器也越来越开放,从最初令开放替换部分图片到慢慢开放可以自由修改其他的导航栏、Banner、状态栏、菜单、登录界面、关于界面,发生了很大的变化,同步我们也提供了Desktop、MDI、Dockable等多种界面风格,可以说客户有更我的选择了。

     随着更多软件企业或组织加入应用AgileEAS.NET SOA中间件行业,有许多的客户已经不能满足于在这几种风格之中进行选择,希望能给自己最大的自定义空间和范围,提供了更换主界面的需求,我们积极的响应这种需求,并且提出了相关的解决方案,并且在2012年AgileEAS.NET SOA 5.0版本的时间向大家提供。

     主界面替换被某一些我们服务于的客户所使用,但是对于广大的关心AgileEAS.NET SOA中间件的朋友来说,并不能得到我们细致并且一对一的服务,因为我们还没有变此部分内容给大家做过介绍和在公开的案例之中提供,所以对于社区之中的很多朋友来说,还能灵活的应用本部分内容。

     下图是一个典型的AgileEAS.NET SOA中间件平台WinClient容器的主界面:

untitled

     其中包含以下组成部分:

 

     主菜单:界面最上部的主菜单,系统、视图和帮助。

     导航菜单:通过菜单之中的菜单项可以打开指点的功能模块。

     导航栏:同系统导航菜单、以树形或者其他形式展示。

     状态栏:显示系统的一些状态信息,如操作消息、当前登录信息等。 
     内容区:除以上项目外的界面空白区域为业务工作区,即模块插件的工作区域,新打开的模块在经区域显示和工作。

     启始页:特指工作区之中第一个打开的模块,当系统登录完成之后会自动打开一个模块,此模块称为起始页模块。

三、IResource接口

     AgileEAS.NET SOA 中间件平台为了应用对运行容器的各个部分进行自定义和扩展,提供了一个资源接口IResource:

   1: using System;
   2:  
   3: namespace EAS.Explorer
   4: {
   5:     /// <summary>
   6:     /// 运行容器的外壳资源。
   7:     /// </summary>
   8:     public interface IResource
   9:     {
  10:         /// <summary>
  11:         /// 获取应用系统的图标,用于替换主界面的图标。
  12:         /// </summary>
  13:         System.Drawing.Icon GetMainIcon();
  14:  
  15:         /// <summary>
  16:         /// 获取默认的模块图标,用于简约、经典风格的Tab页图标显示,也用于Desktop模式的桌面图标显示。
  17:         /// </summary>
  18:         System.Drawing.Image GetModuleIcon();
  19:  
  20:         /// <summary>
  21:         /// 获取桌面背景图像,用于Desktop模式的桌面模块。
  22:         /// </summary>
  23:         System.Drawing.Image GetDesktopImage();
  24:  
  25:         /// <summary>
  26:         /// 获取应用系统的导航控件,用于替换平台的导航控件。
  27:         /// </summary>
  28:         /// <returns>WinForm/WPF用户控件。</returns>
  29:         object GetNavigationControl(); 
  30:  
  31:         /// <summary>
  32:         /// 获取应用系统的Banner控件,用于替换平台的Banner条。
  33:         /// </summary>
  34:         /// <returns>WinForm/WPF用户控件。</returns>
  35:         object GetBannerControl(); 
  36:  
  37:         /// <summary>
  38:         /// 获取应用系统的Bottom控件,用于替换平台的状态栏。
  39:         /// </summary>
  40:         /// <returns>WinForm/WPF用户控件。</returns>
  41:         object GetBottomControl(); 
  42:  
  43:          /// <summary>
  44:         /// 获取WinForm/WPF容器的关于对话框,用于替换平台的关于对话框。
  45:         /// </summary>
  46:         /// <returns>WinForm/WPF窗体。</returns>
  47:         object GetAboutForm();
  48:  
  49:         /// <summary>
  50:         /// 获取WinForm/WPF容器的主界面,用于替换平台的主界面。
  51:         /// </summary>
  52:         /// <returns>WinForm/WPF窗体。</returns>
  53:         object GetMainShell();        
  54:  
  55:         /// <summary>
  56:         /// 获取WinForm/WPF/Silverlight容器的登录对话框,用于替换平台的登录对话框。
  57:         /// </summary>
  58:         /// <returns>WinForm/WPF/Silverlight窗体。</returns>
  59:         ILoginForm GetLoginForm();
  60:  
  61:         /// <summary>
  62:         /// 获取WinForm/WPF容器的起始页/初始模块,用于替换平台的起始页。
  63:         /// </summary>
  64:         /// <returns>WinForm/WPF用户控件。</returns>
  65:         object GetStartModule();
  66:  
  67:         /// <summary>
  68:         /// 获取系统的名称,显示在运行环境的导航栏。
  69:         /// </summary>
  70:         /// <returns>应用系统名称。</returns>
  71:         string GetApplicationName();
  72:  
  73:         /// <summary>
  74:         /// 获取系统的标题,显示在运行环境的主窗口之上。
  75:         /// </summary>
  76:         /// <returns>应用系统名称。</returns>
  77:         string GetApplicationTitle();
  78:  
  79:         /// <summary>
  80:         /// 是否显示主菜单。
  81:         /// </summary>
  82:         bool DisplayMainMenu
  83:         {
  84:             get;
  85:         }
  86:  
  87:         /// <summary>
  88:         /// 是否显示导航工具条。
  89:         /// </summary>
  90:         bool DisplayNavigationTool
  91:         {
  92:             get;
  93:         }
  94:     }
  95: }

     实现AgileEAS.NET SOA 平台的资源替换即是实现IResource接口的过程,在我们DrugShop、SmartERP案例之中都有对应的实现项目DrugShop.Res和SmartERP.Res。

     当然,光实现IResource还不购,还需要修改系统的配置文件,以便让资源生效:

   1: <;!--资源-->
   2: <object name="EAS.Explorer.Resource" assembly="DrugShop.Res" type="DrugShop.Res.Resources" LifestyleType="Singleton"/>

     需要注意的是在EAS.Explorer.dll程序集之中还定义了以下两个接口,INavigation接口:

   1: using System;
   2: using System.Collections.Generic;
   3: using System.Linq;
   4: using System.Text;
   5: using System.Text.RegularExpressions;
   6: 
   7: namespace EAS.Explorer
   8: {
   9:     /// <;summary>
  10:     /// 导航控件接口。
  11:     /// <;/summary>
  12:     public interface INavigation
  13:     {
  14:         /// <;summary>
  15:         /// 初始化导航。
  16:         /// <;/summary>
  17:         /// <;param name="m_GroupList">导航清单。</param>
  18:         /// <;param name="m_ModuleList">模块清单。</param>
  19:         void Initialize(IList<;INavigateGroup> m_GroupList, IList<INavigateModule> m_ModuleList);
  20:     }
  21: }

     ILoginForm接口:

   1: using System;
   2: using System.Collections.Generic;
   3: using System.Linq;
   4: using System.Text;
   5:  
   6: namespace EAS.Explorer
   7: {
   8:     /// <;summary>
   9:     ///  定义登记对话框接口,用于实现自定义登录。
  10:     /// <;/summary>
  11:     public interface ILoginForm
  12:     {
  13:         /// <;summary>
  14:         /// 是否已经通过登录验证。
  15:         /// <;/summary>
  16:         bool Passed { get; }
  17:     }
  18: }

     自定义的导航控件必须实现INavigation接口,以便于平台实现导航的初始化,方法Initialize由平台调用,传入当前系统登录人员所具有权限的模块清单及相关的导航清单。

     自定我的登录界面必须实现ILoginForm,以便于系统判定登录界面是否完成了登录验证。

四、IMainShell接口和自定义主界面

     第三节在介绍IResource接口的时候我们会发现其他有一个GetMainShell()方法,其用于获取资源实现之中的主界面定义,系统主界面必须是一个Form并且要实现IMainShell接口:

   1: using System;
   2: using System.Collections.Generic;
   3: using System.Linq;
   4: using System.Text;
   5:  
   6: namespace EAS.Explorer
   7: {
   8:     /// <;summary>
   9:     /// 定义主界面接口,用于实现自定义主界面。
  10:     /// <;/summary>
  11:     public interface IMainShell
  12:     {
  13:         /// <;summary>
  14:         /// 初始化主界面,根据平台传入的模块清单和相关的导航分组初始化主界面。
  15:         /// <;/summary>
  16:         /// <;param name="m_GroupList">导航清单。</param>
  17:         /// <;param name="m_ModuleList">模块清单。</param>
  18:         void InitializeShell(IList<;INavigateGroup> m_GroupList, IList<INavigateModule> m_ModuleList);
  19:  
  20:         /// <;summary>
  21:         /// 加载/打开指定模块,响应系统的模块打开操作。
  22:         /// <;/summary>
  23:         /// <;param name="module">模块实例。</param>
  24:         void OpenModule(object module);
  25: 
  26:         /// <summary>
  27:         /// 关闭当前模块(活动的模块)。
  28:         /// <;/summary>
  29:         void CloseModule();
  30: 
  31:         /// <summary>
  32:         /// 关闭指定模块。
  33:         /// <;/summary>
  34:         /// <;param name="module">模块实例。</param>
  35:         void CloseModule(object module);
  36: 
  37:         /// <summary>
  38:         /// 切换导航,展开、隐藏导航,主界面没有导航的隐藏、展开需求可以不处理。
  39:         /// <;/summary>
  40:         void SwitchNavigation();
  41: 
  42:         /// <summary>
  43:         /// 当前活动插件/模块。
  44:         /// <;/summary>
  45:         object ActiveAddIn
  46:         {
  47:             get;
  48:         }
  49:  
  50:         /// <;summary>
  51:         /// 已打开的插件/模块集合。
  52:         /// <;/summary>
  53:         List<;object> AddIns
  54:         {
  55:             get;
  56:         }
  57:     }
  58: }

     其中InitializeShell方法:用于平台传入当前系统登录人员所具有权限的模块清单及相关的导航清单,由自定义界面实现界面的初始化。

     OpenModule方法:用于实现对模块的打开,平台传入要打开的模块,由主界面进行处理,实现主界面对模块的动态加载。

     CloseModule方法:用于关闭已经打开的模块,并对界面进行清理。

     SwitchNavigation方法:切换导航,展开、隐藏导航,主界面没有导航的隐藏、展开需求可以不处理。

     ActiveAddIn属性:向平台返回当前的活动模块。

     AddIns属性:向平台返回已加载的模块清单。

四、自定义界面实例

     近期 有朋友建议使用devcomponents或者DotNetBar为大家演示一下如何自定义平台的主体界面,参考了网有对devcomponents和DotNetBar相关的资料之后我们选择了较为轻量级的DotNetBar为大家演示如何替换系统的主界面。

     我们使用DotNetBar所提供的一些控件实现了以下三种风格的主体界面:

     第一种是Win7/Ribbon风格的主界面RibbonShell,如下图所示:

image

     其对应代码为DrugShop案例之中的DrugShop.Res项目之中的RibbonShell.cs程序文件。

     第二种为类似Visual Studio界面风格的DockableShell,其效果如下:

image

     其对应代码为DrugShop案例之中的DrugShop.Res项目之中的DockableShell.cs程序文件。

     第三种为不包含导航栏的简单MDI界面风格的TabShell,其效果如下:

image

     其对应代码为DrugShop案例之中的DrugShop.Res项目之中的TabShell.cs程序文件。

五、关于代码

     以上介绍了三种风格的自定义主界面的例子,例子不多,也不复杂,或许也不能满足所有人的美观度需求和功能需求,其目的在于抛砖引用,希望借此文让更多的开发者加入到我们的行列之中来,做出更加美观大方的界面。

     关于以上三种风格自定义界面代码,我们已经合并到DrugShop案例SmartEPR案例之中,请大家在AgileEAS.NET SOA中间件官方网站最新下载栏目进行下载。

     在启动自定义界面的过程之中切记要修改资源项目之中IResource的实现代码之中的GetMainShell方法代码:

   1: public object GetMainShell()
   2: {
   3:     return new RibbonShell(); //Ribbon风格自定义界面。
   4:     //return new DockableShell(); //Dockable风格自定义界面。
   5:     //return new TabShell(); //TabMdi风格自定义界面。
   6:     //return null; //使用AgileEAS.NET SOA平台自带界面。
   7: }

    本文所使用的是DotNetBar115版本,有关于DotNetBar115请通过http://42.121.30.77/downloads/DotNetBar115.rar下载。

六、联系我们

     为完善、改进和推广AgileEAS.NET而成立了敏捷软件工程实验室,是一家研究、推广和发展新技术,并致力于提供具有自主知识产权的业务基础平台软件,以及基于业务基础平台开发的管理软件的专业软件提供商。主要业务是为客户提供软件企业研发管理解决方案、企业管理软件开发,以及相关的技术支持,管理及技术咨询与培训业务。

     AgileEAS.NET SOA中间件平台自2004年秋呱呱落地一来,我就一直在逐步完善和改进,也被应用于保险、医疗、电子商务、房地产、铁路、教育等多个应用,但一直都是以我个人在推广,2010年因为我辞职休息,我就想到把AgileEAS.NET推向市场,让更多的人使用。

     我的技术团队成员都是合作多年的老朋友,因为这个平台是免费的,所以也没有什么收入,都是由程序员的那种理想与信念坚持,在此我感谢一起奋斗的朋友。

团队网站:http://www.agilelab.cn

AgileEAS.NET网站:http://www.smarteas.net

官方博客:http://eastjade.cnblogs.com

QQ:47920381,AgileEAS.NET

QQ群:113723486(AgileEAS SOA 平台)/上限1000人

199463175(AgileEAS SOA 交流)/上限1000人

212867943(AgileEAS.NET研究)/上限500人

147168308(AgileEAS.NET应用)/上限500人

172060626(深度AgileEAS.NET平台)/上限500人

116773358(AgileEAS.NET 平台)/上限500人

125643764(AgileEAS.NET探讨)/上限500人

193486983(AgileEAS.NET 平台)/上限500人

邮件:james@agilelab.cn,mail.james@qq.com,

电话:18629261335。


    本文转自魏琼东博客园博客,原文链接:http://www.cnblogs.com/eastjade/p/3479081.html,如需转载请自行联系原作者

相关文章
|
11天前
|
存储 设计模式 编解码
.NET 8.0 通用管理平台,支持模块化、WinForms 和 WPF
【11月更文挑战第5天】本文分析了.NET 8.0 通用管理平台在模块化、WinForms 和 WPF 方面的优势。模块化设计提升了系统的可维护性和可扩展性,提高了代码复用性;WinForms 提供了丰富的控件库和简单易用的开发模式,技术成熟稳定;WPF 支持强大的数据绑定和 MVVM 模式,具备丰富的图形和动画功能,以及灵活的布局系统。
|
1月前
|
Windows
.NET 隐藏/自定义windows系统光标
【10月更文挑战第20天】在.NET中,可以使用`Cursor`类来控制光标。要隐藏光标,可将光标设置为`Cursors.None`。此外,还可以通过从文件或资源加载自定义光标来更改光标的样式。例如,在表单加载时设置`this.Cursor = Cursors.None`隐藏光标,或使用`Cursor.FromFile`方法加载自定义光标文件,也可以将光标文件添加到项目资源中并通过资源管理器加载。这些方法适用于整个表单或特定控件。
|
3月前
|
开发框架 .NET Docker
【Azure 应用服务】App Service .NET Core项目在Program.cs中自定义添加的logger.LogInformation,部署到App Service上后日志不显示Log Stream中的问题
【Azure 应用服务】App Service .NET Core项目在Program.cs中自定义添加的logger.LogInformation,部署到App Service上后日志不显示Log Stream中的问题
|
3月前
|
开发者 API Windows
从怀旧到革新:看WinForms如何在保持向后兼容性的前提下,借助.NET新平台的力量实现自我进化与应用现代化,让经典桌面应用焕发第二春——我们的WinForms应用转型之路深度剖析
【8月更文挑战第31天】在Windows桌面应用开发中,Windows Forms(WinForms)依然是许多开发者的首选。尽管.NET Framework已演进至.NET 5 及更高版本,WinForms 仍作为核心组件保留,支持现有代码库的同时引入新特性。开发者可将项目迁移至.NET Core,享受性能提升和跨平台能力。迁移时需注意API变更,确保应用平稳过渡。通过自定义样式或第三方控件库,还可增强视觉效果。结合.NET新功能,WinForms 应用不仅能延续既有投资,还能焕发新生。 示例代码展示了如何在.NET Core中创建包含按钮和标签的基本窗口,实现简单的用户交互。
67 0
|
5月前
|
安全 程序员 Shell
老程序员分享:NSIS自定义界面,下载并安装Net.Framework4.8
老程序员分享:NSIS自定义界面,下载并安装Net.Framework4.8
|
5月前
|
存储 分布式计算 大数据
MaxCompute操作报错合集之自定义udf的函数,引用了import net.sourceforge.pinyin4j.PinyinHelper;但是上传资源后,出现报错,是什么原因
MaxCompute是阿里云提供的大规模离线数据处理服务,用于大数据分析、挖掘和报表生成等场景。在使用MaxCompute进行数据处理时,可能会遇到各种操作报错。以下是一些常见的MaxCompute操作报错及其可能的原因与解决措施的合集。
107 0
|
6月前
|
数据采集 存储 监控
.NET智慧手术室管理平台源码
术前访视记录单、手术风险评估表、手术安全核查表、自费药品或耗材、麻醉知情同意书、麻醉记录单、分娩镇痛记录单、麻醉复苏单、术后镇痛记录单、术后访视记录单、压伤风险评估量表、手术清点记录单、护理记录单、输血护理记录单。
121 0
|
2月前
|
开发框架 前端开发 JavaScript
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
41 7
|
2月前
|
存储 开发框架 前端开发
ASP.NET MVC 迅速集成 SignalR
ASP.NET MVC 迅速集成 SignalR
58 0
|
3月前
|
开发框架 前端开发 .NET
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
48 0