方法是只需设置cxGridPopupMenu1的属性Grid为cxGrid1DBTableView1的cxGrid

时间:2022-02-22 04:10:36

2.统计成果
解决:(1) tableview
1. tableview1的optionsviewfooter=ture
2.然后在cxGRid1的customize..中的summary 的footer.add需要合计的列kind= skSum
在Footer的第一列显示[合计:]  
加一个Summary项,Column设为Grid的第一列,Kind设为skNone  
在该Summary项的OnGetText事件中,输入:  
procedure   TFormExpense.tvExpenseTcxGridDBDataControllerTcxDataSummaryFooterSummaryItems2GetText( 
      Sender:   TcxDataSummaryItem;   const   AValue:   Variant;   AIsFooter:   Boolean;  
      var   AText:   String);  
begin  
      AText   :=   ‘合计:‘;  
end;


      (2) 按条件汇总:  
在TableView的DataController->Summary->FooterSummary->OnSummary事件中,输入: 
procedure   TFormExpense.tvExpenseDataControllerSummaryFooterSummaryItemsSummary(  
      ASender:   TcxDataSummaryItems;   Arguments:   TcxSummaryEventArguments;  
      var   OutArguments:   TcxSummaryEventOutArguments);  
begin  
      //得到字段名   TcxDBDataSummaryItem(Arguments.SummaryItem).FieldName;  
      if (ASender.DataController.Values[Arguments.RecordIndex,   tvExpenseLevel.Index]   >   1)       //只统计Level列=1的值  
          and (TcxDBDataSummaryItem(Arguments.SummaryItem).Kind   =   skSum)   then  
          OutArguments.Value   :=   0; //Level   >   1的统计值设为0  
end;

OptionView中属性GroupFooters设为gfAlwaysVisible并设置需要求和的列,

在summary.default for Groups 下add插手需要合计的字段,column下显示fieldname 为统计字段,format为格局,kind为统计要领,position 为位子 spfooter 在分组的下面,spgroup 在分组的上面
或用cxGridPopupMenu1,在运行時可对任意数字类型列求和,要领是只需设置cxGridPopupMenu1的属性Grid为cxGrid1DBTableView1的cxGrid,

***************************************************************************** 

3.去失cxgrid 中的过滤下拉箭头
解决: 选择tableview1.optionscustomize.columnfiltering=fasle;

**************************************************************************** 

4.让“Drag a column here to group by that column”不显示
   解决:在cxGrid1DBTableView1->optionsview->groupbybox:=false即可

****************************************************************************

5.GroupPanel上面的英文[Drag a column header to group by that column]怎么可以改成中文
解决:最简单的要领是 TcxGridTableView.OnCustomDrawPartBackground,
也可用 OnCustomDrawGroupCell:

procedure TForm1.cxGrid1DBTableView1CustomDrawPartBackground(Sender: TcxGridTableView; ACanvas: TcxCanvas;AViewInfo: TcxCustomGridCellViewInfo; var ADone: Boolean);
begin
  AViewInfo.Text:=‘动态设置 GroupBox 的显示内容‘;
  ACanvas.FillRect(AViewInfo.Bounds);
end;
注:改成中文后将字段拖上去中文还是会显示,最好是设置空值

****************************************************************************

6.如何实现如下成果:
+财务部
+原质料货仓
+制品库
+冲压车间
+软件开发部
这个是部门的名称,点击加号就可以将本部门的人员情况显示出来。

解决:其实这是一个主从表关系,1:填好主表的keyfieldnames
2:填好从表的keyfieldnames
3:填好从表的 detaikeyfieldNames与masterkeyfieldnames
4: 从表的数据源必然要按与主表关联的字段排序
注:其它处所设置了主从表布局那样就显示不出来,好比设置了从表的Table或者Query的mastersource和
asterfield就会不能显示数据!如果是两个cxGrid的主从关系,这样设置就很OK了。

****************************************************************************

7.类似PageControl显示

解决:增加一个Level,将cxGrid1->RootLevelOptions->DetailTabsPosition设为dtpTop,然后相应的设置cxGrid1Level1,和cxGrid1Level2的Caption值。

****************************************************************************

8.如何设定左边几列,不能滚动

解决:使用DB Banded Table才可以实现,在cxGrid1DBBandedTableView里成立Band0,Band1
Band0的Fixed=tfLeft
Band1的Fixed=tfnone
设置要锁定的字段的BandIndex=0,其它为1,就OK了。

*******************************************************************************