2) 输入工程名称和路径后点击OK,ECO Application Wizard为我们创建了所需要的工程单元文件。(注意:因为Delphi 8 Eco中存在的一个BUG,在工程路径或工程名中存在全角字符会引起编译器编译是发生错误,这里必须保存在英文路径下)
ECO Application Wizard生成的新工程包含以下几个文件:
文件名描述CoreClasses.pas其中包含UML packages、 interfaces、 classes之间关联关系的源代码和在模型中定义的类型EcoCRMEcoSpace.pas由Borland.Eco.Handles.EcoSpace派生出的子类TEcoCRMEcoSpace的源代码WinForm.pas 应用程序主窗体的源代码Borland.Eco.Core.dll
Borland.Eco.Handles.dll
(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/bianchengyuyan/)Borland.Eco.Interfaces.dll
Borland.Eco.Ocl.ParserCore.dll
Borland.Eco.Persistence.dll 这些文件是ECO applications运行时所需要的文件,存放在C:Program FilesCommon FilesBorland SharedBDSShared Assemblies2.0目录下
2. 需求分析
由上面所提供的需求我们可以提炼出以下几个类:
名称描述Customer客户,包含属性有:Name(名字)、Phone(联系电话) Address(住址)Person 个人客户,除了包括客户的属性外还有Sex(性别)属性Company公司客户,其具有Customer的全部属性Car汽车,包含的属性有ID(汽车编号) Name(汽车名称) CarType(汽车型号)CarSell汽车的销售记录,包含的属性有BuyDate(购车时间)Fee(价格)
本文示例代码或素材下载
各个类之间的对应关系如下:
Person和Company都是Customer的子类,它们都拥有Customer的属性。汽车的销售记录中包含所销售的车辆,CarSell和Car有一对一或一对多的对应关系,也就是一条销售记录可能对应多个车辆,同样客户和销售记录也有一对一或一对多的对应关系。
3. 设计模型
根据上面的分析结果我们可以开始从ECO中进行建模,首先选择模型视图,打开CoreClasses包,然后双击CoreClasses打开模型设计面板。
Tool Palette 中的UML Class Diagram 中共包含6个组件他们分别是:
名称描述Eco Package模型包,如果系统结构复杂可用其来进行分解以降低复杂度,CoreClasses包是ECO Application Wizard默认生成的包Class类Generalization/Implementation 继承关系Association 联合关系Note 注释Note Link注释链接
首先我们将一个Class拖放到设计器中,将其命名为Customer,再点击右键选择 Add →Attribute为其添加一个属性,并设置该属性的名称为"Name"类型为String。在属性的类型设置中,你可以输入Delphi支持的类型。同过设置Alias属性还可以在模型中显示中文别名,方便我们进行建模。Class常用的属性如下:
属性名默认值描述AbstractFalse抽象类Sealed False能否被继承Alias '' 别名,显示在模型编辑器中的名字Persistencepersistent 是否被存储DefaultStringRepresentation'' 默认显示字符,可将其设置为关键的属性名
点击放大
根据我们在上面需求中所分析出的四个类在编辑器中创建,因为Person和Company都是继承自Customer,所以仅仅描述其不同于Customer的属性即可。完成后设计器内容如图所示:
(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/bianchengyuyan/)完成上述工作后,我们开始对模型间的关联关系进行设计,首先来完成Customer的继承关系。选择Tool Palette中的Generalization/Implementation组件,点击Person模型后拖曳到Customer模型去,这样就建立好了两者间的继承关系,同样建立Company与Customer的继承关系。
然后开始建立Customer和CarSell之间的主子对应关系,选择Tool Palette中的Association组件,点击CarSell模型后拖曳到Customer模型去,即生成了一个Association。点击选中Association后设置它的属性,修改其name为PayAssociation,End1的 Multiplicity为0..*;End2的Multiplicity为1。Multiplicity属性用于控制模型间的连接关系,其可选属性的含义为:
可选择值描述0..1 有零个或一个连接1..1有一个且只有一个连接0..*有零个或多个连接1..*有一个或多个连接同理为CarSell和Car建立关联关系,建立完成后的模型图如下:
到此为止我们的建模工作已经完成,在此之后我们还需要把对象保存发布到数据库中,这就用到了Eco所提供到的PersistenceMapper组件。在Delphi 8 中Eco一共提供了13个组件,它们分别是:
编号组件名命名空间功能1 CurrencyManagerHandleBorland.Eco.Handles用来操作当前游标所在的对象实体2 ExpressionHandleBorland.Eco.Handles可以将其简单理解为一个数据源组件(TDataset),数据源通过SQL语句向数据库查询记录,而ExpressionHandle更为灵活可控的OCL语句查询对象实例3 OclPSHandleBorland.Eco.Handles 根据OCL表达式得到元素值,其主要方法为Execute4 OclVariablesBorland.Eco.Handles
本文示例代码或素材下载
定义在OCL中所使用的变量5 ReferenceHandle Borland.Eco.Handles 建立一个数据库连接,在使用中相当于dbConnection6 VariableHandleBorland.Eco.Handles 通常和OclVariables一起使用7 PersistenceMapperBdpBorland.Eco.Persistence 将对象模型通过BdpConnection.进行发布8 PersistenceMapperXMLBorland.Eco.Persistence 将对象模型通过Xml格式.进行发布.9 PersistenceMapperSqlServerBorland.Eco.Persistence 将对象模型通过SqlServer.进行发布10 EcoAutoFormExtenderBorland.Eco.WinForm 自动生成类信息窗体11 EcoActionExtenderBorland.Eco.WinForm 和Button的EcoAction属性绑定,由按钮事件实现对象方法12EcoDragDropExtenderBorland.Eco.WinForm提供Eco对象间在GUI中的拖曳支持13 EcoListActionExtenderBorland.Eco.WinForm 和Button的EcoListAction属性绑定,用以控制CurrencyManagerHandle事件
其中Extender类组件将标准的.Net组件(DataGrid,TextBox等)和ECO进行了关联,这些Extender组件在由ECO Application Wizard创建完成后就自动生成了这些组件,我们不需要手工创建。我们下面用到的PersistenceMapper,是将对象模型发布到数据库或XML中,同时也将对象实例存储到数据库中。如果我们在项目中需要转换数据库平台,不需要作过多的改变,仅仅将PersistenceMapper类型更改以下就可以,实现了真正的数据库平台无关性。在本演示中我们用PersistenceMapperXML来进行数据的存储,在程序完成需要发布时根据需要再改为其它类型的数据库即可。
在工程视图中双击打开EcoCRMEcoSpace.pas,并切换到设计视图,从Tool Palette中双击PersistenceMapperXML,添加一个PersistenceMapperXML到设计器中,设置其FileName属性为"EcoCrmData.xml",并将TEcoCRMEcoSpace的PersistenceMapper属性设置为PersistenceMapperXML。
点击放大(上图)
4. 编码
下面我们要完成的就是界面设计、编码工作。在工程视图中双击WinForm.pas打开窗体编辑器。ECO Application Wizard已经创建了一个ReferenceHandle组件rhRoot和多个Extender组件。Extender组件保留其默认属性即可,如果将其删除用户界面中的控件将无法和ECO关联。设置rhRoot的EcoSpaceType 为 "EcoCRMEcoSpace.TEcoCRMEcoSpace",如果在EcoSpaceType属性下拉列表中没有选项,可重新编译一下工程。
在界面上放置6个DataGrid,分别将其重命名为dgPersons、dgCompanys、dgCompanyCars、dgPersonCarSells、dgCompanyCars、dgPersonCars,为使界面更清晰可以分别设定一下DataGrid的CaptionText。并且在每个DataGrid上放置两个按钮,其Text分别为"添加"、"删除"。完成界面设计为如下样式。
点击放大
用户界面中的组件需要和ExpressionHandle相连接才能显示感知对象实例。在这里ExpressionHandle与Delphi中Dateset的概念很类似,它是一组数据的集合。向窗体编辑器中新添加一个ExpressionHandle,设置其Name属性为ehCompanys,其RootHandle属性为rhRoot,双击Expression打开OCL Expression编辑器。OCL Expression编辑器很类似于我们以前用的SQL编辑器,不过它使用的是OCL语法,在系统发布运行后ECO会根据不同的数据库平台将OCL翻译成相应的SQL进行执行。在OCL Expression编辑器中输入"Company.allInstances",它的含义是取得Company的所有对象实例,我们可以将它等效理解为SQL语句中的" Select * from Company"。
点击放大
同样我们为其他的几个类建立对应的ExpressionHandle,它们的名字分别为ehPersons、ehCompanyCarSells、ehPersonCarSells、ehCompanyCars、ehPersonCars。为实现主子表关联关系我们还需要CurrencyManagerHandle组件,添加一个CurrencyManagerHandle组件到设计器中,将其重命名为cmhCompany,设定其RootHandle属性为主对象ehCompany,其BindContext 属性为显示Company列表的dgCompanys。
本文示例代码或素材下载