cxgrid使用

本文介绍了使用cxGrid进行数据过滤的方法,包括编码实现、cxDBFilterControl的应用及事件处理等。同时,还讲解了如何获取和动态设置单元格值。

1编码实现过滤

with gridDBTableView1.DataController.Filter.Root do
  begin
    Clear;
    BoolOperatorKind := fboor;
    AddItem(gridDBTableView1.Columns[15], foEqual,
      trim(myutils.getDepartmentNameFromNodeEx( sel)),trim(myutils.getDepartmentNameFromNodeEx( sel)));
  end;    // with
  gridDBTableView1.DataController.Filter.Active := true; 

2为了实现上述的过滤功能要用到cxfilter单元

3为了重载onCustomDrawPartBackground时间要用到Tcxcanvas要使用cxgraphics单元。

4cxDBFilterControl 的使用

注意的方法: ApplyFilter。将用户创建的filter应用。

但是,该方法继承于TcxCustomFilterControl,对 TcxFilterControl 有效。

对TcxDBFilterContorl,

you should manually apply filter conditions to the underlying dataset based upon the FilterText property setting.  The suitable place to perform this task is a handler for the OnApplyFilter event.

注意上文中的FilterText,用户建立的filter,保存在FilterText中。使用如下:

with cxDBFilterControl1.DataSet do
begin
  Filter := cxDBFilterControl1.FilterText;
  Filtered := True;
end


5 获取指定cell的值,

cxGrid1DBTableView1.Columns[8].EditValue  可以返回数据集当前记录第9列的那个数据。

6动态设置cell的值,

首先要确保将设置值的cell对应的column的type已经被定义过

然后

cxGrid1DBTableView1.DataController.SetValue(
        cxGrid1DBTableView1.DataController.RecNo-1,8,'ddd');
或者

 cxGrid1DBTableView1.DataController.Values[
        cxGrid1DBTableView1.DataController.RecNo-1, 8] := 'ddd';

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值