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';