写C#进行Visio二次开发的系列文章有很多篇了,都是写一些经验总结和技术知识的分享,本文继续来探讨这方面开发的一些心得,主要介绍下WinForm界面的设计和Visio软件的架构设计。
先看看我花了N个月的业余时间完成的软件概貌,然后大家一起讨论下相关的技术知识。
软件界面主要有菜单区、工具条区、图纸内容区、右边的管理区、状态条区等等,主要注意的是采用了ToolStripPanel来进行布局,然后并使用了有名的WeifenLuo.WinFormsUI.Docking.dll控件对图纸内容区、右边的管理区进行控制。
其他就是细致的修改了:如为按钮、菜单添加图片,调整样式等。
Visio的SDK提供了很多基本的操作功能,如下面所示的这些功能,主要都是通过调用其内部函数实现的。
其中文件中的另存为和导出AutoCad的操作是通过下面代码完成的。
SaveFileDialog dlg = new SaveFileDialog();
dlg.FileName = Portal.gc.gVisioImage.VisioName;
dlg.Filter = "Visio文件(*.vsd)|*.vsd|所有文件(*.*)|*.*";
dlg.FilterIndex = 1;
if (dlg.ShowDialog() == DialogResult.OK)
{
if (dlg.FileName.Trim() != string.Empty)
{
if (File.Exists(dlg.FileName))
{
File.Copy(Portal.gc.gVisioTemplateFilePath, dlg.FileName, true);
}
else
File.Copy(Portal.gc.gVisioTemplateFilePath, dlg.FileName);
}
}
dlg.FileName = "";
dlg.Filter = "AutoCAD 绘图 (*.dwg)|*.dwg|所有文件(*.*)|*.*";
VisApplication.ActivePage.Export(dlg.FileName);
其中的视图中有很多Visio的视图窗口需要控制,如形状窗口、自定义属性窗口、扫视缩放窗口、大小位置窗口、其他还有如标尺、网格等显示设置需要控制。这些都是通过调用Application.DoCmd((short)commandID);函数实现的,只要传入了相应的命令ID,那么就达到了控制显示的功能。如自定义属性窗口为VisUICmds.visCmdCustProp,形状窗口为VisUICmds.visCmdShapesWindow,标尺为VisUICmds.visCmdViewRulers,网格为VisUICmds.visCmdViewGrid,这些属性都是可以在SDK中查找到的。
以上的格式和形状菜单项中的操作也是通过Application.DoCmd((short)commandID);函数实现的,只要查询到相应的命令ID即可进行调用,你花点时间看看VisUICmds枚举下都有那些命令ID可以调用就可以了。
再来说说软件的架构设计吧。
整个UI层主要应用了前面介绍过的WeifenLuo.WinFormsUI.Docking.dll的控件(即图中的DockingControl组件),还有就是Visio Drawing Control的OCX控件了(图中的VisioOCX组件)。
两边是各个层中用到的通用类(Commons)和实体类(Entity)。
Visio的二次开发,除了需要操作Visio的文件(包含多个模具文件,Viso文档)还有就是也需要和数据库打交道(没有数据库的程序会逊色很多的)。
为了较好区分和协调他们的访问,我设定了一个访问边界:访问数据库的层不会访问Visio文件对象,访问Visio文件对象的不会去访问数据库,它们统一由业务层(Business)调配,各层之间分享Entity层的信息即可。
数据库的底层访问通过利用Enterprise Library的模块完成,因此DAL层只需要做较少的工作即可完成对数据库的访问了。