Data

Data-Browse型Data-Aware控件的制作

数据挖掘论坛


在MIS系统中,使用得最常见的当属数据感知控件了。学习如何编写自已的组件,一条很重要的原则就是从自己熟悉的
组件入手,派生出新的合乎自己要求的控件。在数据感知控件中,Data-Browse型是非常简单而又实用的。所以下面
我们就讲解一个一个自定义的TSunDBText(功能等同于TDBText)的编写: 数据挖掘工具

TSunDBText = class(TCustomLabel)
 {...}
end; 数据挖掘工具

因为DBText仅起着显示数据的作用,即是个具有数据感知功能的标签,又根据Delphi的习惯,从Custom系列控件派生,
所以我们选择了TCustomLabel。 数据挖掘工具

如何具有数据感知功能,其实大部分的书上都没有讲得很明白,包括Delphi Help。大致上有这么几点,我们慢慢叙述:
一:选择一个能数据感知的DataLink对象,通常我们选用TFieldDataLink,表示仅与一个数据库字段关联
二:组件必须提供DataSource和DataField两个设计时可读写属性
三:组件必须处理FDataLink的OnDataChange事件,以反映数据字段的变化
四:必须提供Notification重载方法,以便当关联的TDataSource组件在设计期或者运行期删除时,能得到通知,并且
      反映出这种改变
五:习惯上,我们还要处理CM_GETDATALINK消息,以符合VCL内部通信的要求
六:为了组件的灵活性,建议提供一个Field属性,以便可以利用TField的方法来增强编程的适用性 数据挖掘研究院

下面我们就来一一讲解:
private
   FDataLink:TFieldDataLink;
  
constructor Create(AOwner:TComponent);override;
begin
   inherited;
   FDataLink := TFieldDataLink.Create; {创建一个TFieldDataLink的对象}
   FDataLink.OnDataChange := DataChange;
   {
  
    将TFieldDataLink对象的OnDataChange事件处理交给TSunDBText的DataChange来处理
    这样就要以感知数据库字段的变化,并且进行自己想要的处理
   
   }
end; 数据挖掘研究院

destructor Destroy;override;
begin
  {
    这里很简单,仅仅是回收资源而已
  }
   FDataLink.Free;
   FDataLink := nil;
   inherited;
end;

从上面我们已经看到,数据感知的关键就在于DataChange事件,大致上我们可以知道,是需要将该字段的显示值赋予
本标签组件的Caption属性即可,所以下面的代码便是做这部分工作的。
(注意,之所以要用GetFieldText来完成赋值工作,是出于多方面的考虑,包括设计期和运行期,及异常情况)
procedure TSunDBText.DataChange(Sender: TObject);
begin
  Caption := GetFieldText; {read only displaytext when make an data browing component}
end;

数据挖掘研究院

function TSunDBText.GetFieldText: String;
begin
  {
 
  正常情况下,只需要取得FDataLink所代表的Field的DisplayText即可,如果你开发的不是Data-Browse控件,请用其他
  Field属性
 
  }
  if(FDataLink <> nil) then
    Result := FDataLink.Field.DisplayText
  else if(csDesigning in ComponentState) then Result := Name else Result := ";
  {
   如果是处在设计期,则标签中显示的是组件的名称,如果是运行期,则标签为空;当然,这只是习惯而已,但对于使用Delphi IDE的人来说,
   几乎就是规则。
  }
end; 数据挖掘交友

如果没有DataSource和DataField这两个属性,那么控件几乎就没法使用了。这也是重要步骤。 数据挖掘交友

    property DataSource:TDataSource read GetDataSource write SetDataSource;
    property DataField:String read GetDataField write SetDataField;
   
    这些方法十分简单,只要存取TFieldDataLink之DataSource和FieldName属性则可。
   
 function TSunDBText.GetDataSource: TDataSource;
begin
  Result := FDataLink.DataSource;
  {仅需简单地返回TFieldDataLink之DataSource属性
   从这就可以看出,DataSource属性的写方法也是对FDataLink赋值}
end; 数据挖掘实验室

procedure TSunDBText.SetDataSource(Value: TDataSource);
begin
  FDataLink.DataSource := Value; {如上所云,对DataSource属性赋值} 数据挖掘工具

  if(Value <> nil) then Value.FreeNotification(self);
  {
    这里很重要,TComponent提供了一个FreeNotification(AComponent:TComponent)方法,这样,当Value释放时,就会自动调用AComponent的Notification
    方法,我们就可以调整对应的Data-Browse控件,以反映这种变化。如TSunDBText对应的DataSource组件删除掉,则应该反映在标签上
  }
end; 数据挖掘研究院

function TSunDBText.GetDataField: String;
begin
  Result := FDataLink.FieldName;  {获得TFieldDataLink之FieldName属性,也就知道了连接的是哪一个数据库字段名称}
end; 数据挖掘交友

procedure TSunDBText.SetDataField(const Value: String);
begin
  FDataLink.FieldName := Value; {这应该不用解释了}
end; 数据挖掘研究院

接上面的,我们说过Notification的由来,下面就进行相关的处理:
procedure TSunDBText.Notification(AComponent: TComponent;
  Operation: TOperation);
begin
  inherited;
  if(Operation = opRemove) and (FDataLink <> nil) and (AComponent = DataSource) then
    DataSource := nil;
end; 数据挖掘研究院

当关联组件被删除时,而且被删除的正好是本身关联的DataSource组件,就应该设置其DataSource属性为空

function TSunDBText.GetField: TField;
begin
  Result := FDataLink.Field;
end;

数据挖掘交友

最后,数据感知控件还要响应CM_GETDATALINK消息。通常处理是将TDataLink作为Message的Result域返回
procedure CMGetDataLink(var Message:TMessage);message CM_GETDATALINK; 数据挖掘工具

procedure CMGetDataLink(var Message:TMessage);
begin
    Message.Result := Integer(FDataLink);
end;
到此,基本上组件的功能就已齐备了,然而,有一点许多组件编写者都没有注意到,即Action的应用。如果自定义组件能融入VCL的Action机制,
必然可以使自定义控件的功能更强大,更为一些高级使用者喜欢。 数据挖掘论坛

下一次,我们就来讲一讲Action之来龙去脉。

[数据挖掘专家] [数据挖掘研究院] [数据挖掘论坛] [数据挖掘实验室]
上一篇:字幕图标控件
下一篇:检查特殊字符的简单VCL
最新评论共有 0 位网友发表了评论 , 查看所有评论
发表评论( 不能超过250字,需审核,请自觉遵守互联网相关政策法规。 )
匿名?
数据挖掘网站导航 数据挖掘论坛导航
  • 数据挖掘工具
  • 数据挖掘论坛
  • DataCruncher - Cognos
  • MineSet - MathSoft
  • Intelligent Miner - GainSmarts
  • Sqlserver - SAS - Clementine
  • CART - Weka - WizSoft
  • NeuroShell - ModelQuest
  • data mining tools - Darwin
  • 数据挖掘交友
  • 数据挖掘博客
  • 数据挖掘工具
  • 数据挖掘资源
  • 数据挖掘技术算法
  • 数据挖掘相关期刊、会议
  • 研究院联盟合作专区
  • 数据挖掘基础与相关技术
  • 数据挖掘厂商与就业
  • 数据挖掘研究者乐园
  • 知名厂商数据挖掘工具资料
  • 国内数据挖掘实验室
  • Foreign Data Mining Lab
  • 热点关注
  • GDI+简介
  • COM与DCOM的区别与联系
  • 使用Delphi解析XML 文档
  • 如何设置delphi/cbuilder/BDE/MSSQL
  • BORLAND在“迫害”程序员?
  • 将image的图片保存为JPG格式图片方法
  • InstallShieldExpressfordelphi制作安装程
  • Real Programmers Use Pascal
  • 关于在COM中使用可选参数的研究
  • TStrings的AddObject方法应用
  • 论坛最新话题
  • Foundations of Statistical Natural Langu
  • Game Theory meet Data Mining: A Recent P
  • System Building: How does it help or hin
  • 数据挖掘与Clementine培训
  • 新手报到
  • 求 SASEM 客户流失预测分析
  • 数据挖掘工程师/搜索研究院—北京——无线
  • 数据挖掘入门介绍(如何着手数据挖掘)
  • Information Overload Survey Results
  • The INEX 2005 Workshop on Element Retrie
  • 相关资讯
  • BORLAND在“迫害”程序员?
  • 李维:我的回忆和一些有趣的事(精彩绝伦)
  • 李维看.net和DELPHI6(含李维照片)
  • 《代码大全》电子版1.01发布了
  • Real Programmers Use Pascal
  • Kylix安装手记
  • Borland与Microsoft关于Delphi的对话
  • InstallShieldExpressfordelphi制作安装程
  • 关于在COM中使用可选参数的研究
  • msagent经典用法
  • 数据挖掘实验室资料
  • 数据挖掘博客地址
  • 数据挖掘实验室网站地址
  • Prepare for Medicare audits by using dat
  • 注册成为SAS用户与爱好者俱乐部会员
  • 水南梅
  • 明日烟
  • 新人报道
  • 下载
  • 厦门服务器托管,450元/月—0592-5177319 高
  • 买空间送域名--0592-5177319 高静