DELPHI中DBGrid中行的定位及着色实现

本文介绍了在DELPHI中如何实现DBGrid数据行的定位及定位后改变行颜色。通过TDataSet的GoToBookmark方法进行数据行定位,OnDrawDataCell事件实现行颜色标记。提供了DyDbgDataLine和DrawLine两个过程的详细代码示例。
摘要由CSDN通过智能技术生成

DELPHIDBGrid中行的定位及着色实现

1 问题的提出

    在对一个数据库系统进行操作的时候,发现不能对DBGrid控件中的数据行定位及在定位到某行后无法对当前行进行明显的标志(例如改变颜色),在往上查找了很多资料,发现基本没有对这个内容的介绍,包括一些动态设顶行的颜色等文章讲的都是在数据初始化时做的操作,而没有在数据源刷新后的重新定位功能,所以下决心解决这个问题,通过一上午对DELPHI帮助的研究和查看相关的资料,稍有小成,现写出来和各位同行共同学习,不当之处请多指教。

2 解决的办法

首先查找TtableTquery控件没有发现能够直接定位数据行的方法,同样查找DBGrid也没有找到相应的能够直接定位到某行数据的函数,然后我就从数据集的类上查找,经过不断努力,终于在TdataSet中发现了一个方法:GoToBookmark,这个方法能够使当前的DBGrid中的记录指针指向你需要指定的行。

在找到这个方法后,问题还只解决了一半,还必须把当前指针指向的数据行改变颜色,就是说必须用一个明显的方式去标志当前选中的行(出了在DBGrid上的那个小的不明显的书签外)这个很显然就是在DBGrid控件中实现了,在DBGrid控件中有一个事件OnDrawDataCell,重载这个方法就可以实现指定的数据行的颜色的改变了。

具体的使用过程如下:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值