cxGrid实现取消过滤和排序后定位到首行(单选和多选)

DataContoller中的函数FocusedRecordIndex没有反应,FocusedRowIndex正常。

cxgrdtvGrid1DBTableView1.DataController.FocusedRecordIndex := 0; //定位到第一行,排序过滤无反应

cxgrdtvGrid1DBTableView1.DataController.FocusedRowIndex := 0; //定位到第一行,排序过滤仍正常

排序对应事件:cxGridDBTableView中的DataController的OnSortingChanged

过滤对应事件:cxGridDBTableView中的DataController的Filter的OnChanged

 

对于“排序”后定位到首行只需要设置dcofocusTopRowAfterSorting为True

 

1、测试cxGrid的cxGridDBBandTableView组件在排序或者过滤以后:(单选:MultSelect属性设置为False)

排序:devexpress1226版本的dcofocusTopRowAfterSorting设置为True即可焦点自动定位到首行,单选状态下有选中行焦点和颜色标示

过滤:默认设置,取消过滤后仍默认过滤时候选中的行,增加cxGridDBTableView中的DataController的Filter的OnChanged如下代码行,会出现取消过滤后选中首行(焦点和选中行颜色同时定位到第一行)

 

复制代码
1 var  
2   Filter: TcxDataFilterCriteria; //定义过滤器对象  
3 begin  
4   with Sender as TcxDataFilterCriteria do   
5     if IsEmpty then  //操作过滤器触发过滤器事件时判断过滤器是否为空,即:是否取消过滤  
6       begin  
7         cxgrdtvGrid1DBTableView1.DataController.FocusedRowIndex := 0; //焦点定位到第一行  
8       end;  
复制代码

 


 

2、针对多选情况变通调整,否则焦点(虚线框可以看见)可以移动,但是选中行颜色标志(背景颜色)不会;(多选:MultSelect属性设置为True)

排序:devexpress1226版本的dcofocusTopRowAfterSorting设置为True即可焦点自动定位到首行,多选状态下只有焦点标示无选中行颜色标示

过滤:默认设置,取消过滤后仍默认过滤时候选中的行,增加cxGridDBTableView中的DataController的Filter的OnChanged如下代码行,会出现取消过滤后无论过滤时候选择的一行还是多选都会在此时只选中首行(焦点和选中行颜色同时定位到第一行)

 

复制代码
 1 var  
 2   Filter: TcxDataFilterCriteria;  
 3 begin  
 4   with Sender as TcxDataFilterCriteria do  
 5     if IsEmpty then  //操作过滤器触发过滤器事件时判断过滤器是否为空,即:是否取消过滤  
 6   
 7       begin  
 8         cxgrdtvGrid1DBTableView1.OptionsSelection.MultiSelect := False;  
 9         cxgrdtvGrid1DBTableView1.DataController.FocusedRowIndex := 0; <span style="font-size:14px;font-family:Arial;">//焦点定位到第一行</span>  
10         cxgrdtvGrid1DBTableView1.OptionsSelection.MultiSelect := True;  
11       end;  
12  
复制代码

 

 

3、cxGrid1DBTableView的OptionsView属性中的FocusRect为False就可以看不见虚线框,即获得焦点行的边框

 

4、在多选的情况下,按照以上所说的排序和过滤会出现,排序后焦点定位到第一行但是默认没有选中(背景色为白色),而取消过滤后焦点定位到第一行而且默认第一行选中(背景色为蓝色或者其他操作系统主题颜色),这样就不一致了,临时解决方案:

都只定位到第一行并且都不选择任何行,只需要对过滤后的事件代码做一个刷新调整即可:

 

复制代码
1 var  
2   Filter: TcxDataFilterCriteria;  
3 begin  
4   with Sender as TcxDataFilterCriteria do  
5     if IsEmpty then  
6       begin  
7        cxgrdtvGrid1DBTableView1.DataController.DataSet.Active := False;  
8        cxgrdtvGrid1DBTableView1.DataController.DataSet.Active := True;  
9       end;  
复制代码

 

posted @   Thenext  阅读(416)  评论(1编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
历史上的今天:
2021-04-23 postgresql 时间戳自动更新
点击右上角即可分享
微信分享提示