在TDBGrid控件中为作修改过的记录进行标识!

2016-02-19 12:38 35 1 收藏

今天图老师小编给大家精心推荐个在TDBGrid控件中为作修改过的记录进行标识!教程,一起来看看过程究竟如何进行吧!喜欢还请点个赞哦~

【 tulaoshi.com - 编程语言 】

  unit testDBG;

  interface

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

  uses
    Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
    Dialogs, Grids, DBGrids, DB, ADODB, StdCtrls,Types;

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

  type
    TForm1 = class(TForm)
      DBG: TDBGrid;
      ADOConnection1: TADOConnection;
      ADOTable1: TADOTable;
      DataSource1: TDataSource;
      procedure DBGDrawColumnCell(Sender: TObject; const Rect: TRect;
        DataCol: Integer; Column: TColumn; State: TGridDrawState);
      procedure DBGKeyPress(Sender: TObject; var Key: Char);
      procedure FormCreate(Sender: TObject);
    private
      { Private declarations }
    public
      { Public declarations }
    end;

  var
    Form1: TForm1;
  implementation

  {$R *.dfm}
  type
  MyRect=array[0..200] of Tpoint;
  var
  ME:MyRect;//记录已经修改过记录的单元格的左上叫的点
  i:integer;
  Cpoint:Tpoint;//当前单元格左上角的点

  procedure TForm1.DBGDrawColumnCell(Sender: TObject; const Rect: TRect;
    DataCol: Integer; Column: TColumn; State: TGridDrawState);
  var
  J:integer;
  begin
    if (gdFocused in State) {or (gdSelected in State) or (gdFixed in state)} then
    begin
  {下面的语句是记录格当前活动单元格的左上角坐标}
      Cpoint.X:=rect.Left;
      cpoint.Y:=rect.Top;
    end;
    for J:=0 to I do
    begin
      if (rect.Top=me[j].Y) and (rect.left=me[j].X) then
      begin//判断该单元格是否存在于已修改的数组的记录中!
      dbg.Canvas.Brush.Color:=clRed;
      dbg.DefaultDrawColumnCell(rect,Datacol,column,state);
      end;
    end;
  end;

  procedure TForm1.DBGKeyPress(Sender: TObject; var Key: Char);
  {由于没有找到更好的记录点,所以如果修改的时候只按了一个按键的话将不会触发这个语句!
  因为第一次执行这个语句的时候数据还没有处于修改或者插入状态,本人只测试了修改状态,添加状态没测试过!}
  var
  J:integer;
  begin
    if dbg.DataSource.DataSet.State in [dsEdit, dsInsert] then
      begin//处于就该状态:
        for J:=0 to i do
        begin//判断该格是否已经记录了
          if (me[j].X=cpoint.X) and (me[j].Y=cpoint.Y) then
            exit;
        end;//如果没记录就把它记录下来!
        me[i].X:=cpoint.X;
        me[i].Y:=cpoint.Y;
        i:=i+1;
      end;
  end;

  procedure TForm1.FormCreate(Sender: TObject);
  begin
    I:=0;//初始化数组起点
  end;

  end.

  本人只是做了修改的测试,是成功的,这么少的代码肯定是不能符合大家的更高的需求,这里只是完成了最基本的功能,方便大家理解,有什么更高的要求当然是根据各人的需要,玩一些数字游戏罢了!大家可以把它修改成更安全,更好用的东西!

  谢谢大家的捧场!

来源:http://www.tulaoshi.com/n/20160219/1601373.html

延伸阅读
标签: excel
Excel条件格式自动标识特定的记录   Excel的条件格式功能是一项十分强大且便利的功能。下面介绍自已在使用Excel过程中,利用条件格式功能的其中一个应用场景。 在一个Excel工作表中,有许多条记录,如何使Excel自动标识出满足特定条件的记录呢? 例如:下图所示的工作表中有多条记录,要求当字段是否完成列中为否时,突出标...
标签: Web开发
在WEB应用中,如何才能使应用高效率呢?如何才能吸引用户呢?这的确是个大学问,页面的内容,色搭配等都十分重要。但不可忽视的是,多数情况下,对于数据的呈现方式也是十分重要的。由于web应用的规模不断增大,数据也越来越多了,有时候,由于在一个页面同时显示的数据太多,从而造成页面的不美观,用户因此也会感到厌倦和操作困难。因此,本文...
标签: Web开发
利用ajax组件怎样能让它跟server控件交互呢,例如输出一个列表,就只有用js一条一条html的输出吗?当然不是,现在可以与datagrid交互。 注:ajax的.net组件可以到此网下载,本文用的是for .net 1.1版本的。http://ajax.schwarz-interactive.de/ 1. 在引用中添加引用Ajax.dll。(这个很废话) 2.在web.config中建立HttpHandler(这个当然是在...
树视控件在多文档中的使用 作者 5icomputer 下载源代码     自从来到我们的论坛以来,认识了很多的朋友和编程的高手,从中学到了很多知识。我看在论坛中有很多人问关于树控的问题。故将树控的一些问题写出来,以供大家参考,同时也作为近一段时间来学习的总结。 &nbs...
1、准备 GPS(Global Positioning System),即全球定位系统,利用24颗GPS卫星的测距和测时功能进行全球定位,在许多系统中,如机场导航系统,出租车辆管理和调度系统、江河流域的灾害信息管理和预测系统中,GPS得到了广泛的应用。本文利用MSCOMM控件实现了GPS数据的采集,可为信息管理和指挥调度等提供定位数据。 本文采用GPS的...

经验教程

94

收藏

9
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部